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Abstract of JP 2000149035 (A) 

PROBLEM TO BE SOLVED: To decide crossing 
order among sides of a graphic object and to decide 
on the crossing value of the sides regarding each 
side for a following scan line by evaluating side 
record corresponding to the present scan line. 
SOLUTION: Object graphic description 1 1 is 
generated by a host processor or guided from a 
system ROM and is used for describing parameters 
of the graphic object. The object graphic description 
1 1 is interpreted by a pixel sequential rendering 
device 20 for rendering a pixel base image from 
which it is generated. For example, an object with 
sides is incorporated in several formats, including an 
orthogonal side format in which a two-dimensional 
object, is defined by a straight side (a simple vector) 
to cross from one point to another on a display or 
plural sides, including orthogonal lines in the object 
graphic description 11. 
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[W**4 0] ME*#tt\ iEfri-S^T 1 

4, Wf-SSUWY^r y7"fiSr^tf^4*!|#m4i-5W 
*JJ3 9 KfESJW^ifc. 
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i±. $<**^y7^ vKft^5B^{£e«i:£iiR4t 
<nm , £ffi&-1~ttM£. ^&.<r>x.**S7 4 '/commit 

ai-s.mferotet. »«^*irv?-f >-K:*jrt6iiS« 

Kfcto* S ft 5 2 & *tr r 4 4 + 
3 9KfattC0*fc 

{4.aro1ISr^i66S.ffi»^ :5 r J r>'5-l' yd SSI'S 1 ~ 

<£E£M£-t5fc&6tD&ro >7-f vol ~N- 1 
9croHS*rilR4-r5fc*tJP»*HS ~ t Sr#iHc4-f St* 

j£-f5C0tc:ffli/>f.n5^1 ro»»wB*ffi*«:«*TS* 

1 2icta«w*-ft. 
[«*«4 5] flflta^atts «-** s W^i-5)fe4^)S 

( j ) ffHE€-Ws!Hfifr'>* < 4 fe 2-ow^«(c»lt> ^ 

, «4f5^.r-7 7'4. 
(k) ^fcjKv^fT^w&^rofflroSii-f Sfi^fcifciS 

5/7-4, 

(l) ftriiS^fcHJRW-BBUTfet'FaWKi:*:** 
«iMt< 4t~'3W^4rii^-t-5^7 i y74, 
(m) jS£ro?**R*CLfci»*o-C, 

(n) aRSixfc*«K:»+*fe-^aM«»« ro S" ;:: 
^^gw?pr^fi!c$tL5m2(D?n-c-^fr, flc^A 

&t1-Z* fyT-t «:fiix.5 ^ 4 Sr#iSS4 -fSM** 1 

ev^«*l. ^^fT" (1) ~ (n) ijsjifflSixaa- 



[»#Jf48] flfflE^ryT' (j ) ~ (l ) O^fft 

5 n ir i:1-5ft*l4 5 i'|B«»*)feo 

[it*«4 9] BulE^7 1 y7 p (m) fi, WfS-TSflSIB io 

lit (so) gftMHxn&i^anftfa (do) & 
(j) tmnwm*kntmwm<o&*<D&.b*%im& 

«*]E*flsL-C, fc£lc*aH4«« <(so), (d 
o) } t, «iro££fc8Wfc«« { (l-s o) , (l 
-do) } <tv>#< i^orofiS&fc^ii^S*^^ 20 
i, 

(k) i tM*mnwt#xMm«mmkmfT\*xse* 

( i ) l«flBH*ro^«5c«W* ( s o x (i - d 
o) } 

(ii) m\k amtmmnsimto isoxdoi 

(iii) SfflM*«^<7)B«H9MSi ( (l-so) xd 
o} 

( i ) Ttummk %tm<n$tw& (scxdci ®&m 3° 
^ro 7 * * s* t$ o -c ^ $ n t m%\m ^mm&fit. 

(m) r o p tfmi£m%<0 7 X?fcWZ%-fi><Dk L 
t, sc (soX(l — do)), (s o X d o) (s 
c rop dclSWdc ((1-ie) Xdo) 

#mt1-5SS*«l Sfdil 2K|5««*-»„ 

fS*«5 OK:fHgtCD#j£,, 
[W*JI5 2] ftffft/jlr£«*SWg£-i*Sigli, mJta 

W«ft«r*i- S» 1 JttWB 2 fl5H*«4rBf S w^ritW* 
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(j) WjE*M«*'>4<fcb2oro**c$W x ft 
(k) ^:»g;^9?T#co#*«F H I 3wSS-r6^Sr^ 
(l) ^$Hfcli*fflKIHUTfei^a5^Si:*^4- 

(m) gif^»7^^iiimi-Lfci4SoT, mviztitzm® 
tot, sw^nfcMW-wtsfe-^a^^wffirosi 

^B»S«fe1i&W*L, ^2C0fnS-^^-/$H^<O5F 
EWB#*l:*t«t577^t«<.. ml!Etgl<oftfi 

ft. 

[fS#JS 5 4 ] miE^y 5?* * h CO^B^^sS;^ 
*5tu^/ncML,T, WW©***-?, 

^ V a >■© -o ^ < fllBT ^ 7 > a y 
*ff SrHJBWttt-fr-*-*^ 7 y/t SHI*. 5 r fc 3r» 

t i *fctt i 2 icfaero^fe, 

[IS*JS 5 6 ] jtfjfET ^f^-v'aV fc^tt, 



13 

5 9 ] i»E^««a»4, urts-f ^ -3>0>»* 

Wfc*itfl:3 ftfefca-Cfca r fc -f 5 

* £ ft fc sfr la -r ^ - >> * mm -t z> <o t m # $ ft 5 hsus 
s ^fB«ro^& 

[»**6 l ] ttET^y ^*fl=©WW 

«ri)S *. 5 r t £#m t n ** 6 o izmm n^te, 

[It** 6 2 ] flJE-f ;< - S?tt. '>ft < 4 tlfSI^- 

#»i-6'*< »fWari:«rW»ti-*lll**S 5 ME 

[igsRI 6 4 ] itulE^T- y 7-ra'>* < k fc —oAK m 
UiW7 f'yayk WET i> r >c •> a v ^(tw^- 
7V^Mt 5 r fc &£tr r k*W$k 1-5!t*if5 4 

[«#«e 5 ] fiEtogtt, ftii{b$ftfc-g-fKiS«.^ 

^f5^5 *0.a*ffix., fflEl^lSliiWlE^9:7-f 
y9*-?Vx.9 Y<D&*\-m%<r>7ij h? 

m&nmm^iti-tzmmzfcfc-tzxT-ys'k, $mm 

huE^W'>^< fc fc-otc*hJ-3'>&< fc fc-oro# 

[ W*Jl 6 6 ] iffiE* 7 1 y 7»'>& < fc fc — OiK fi 
Eft^T ? •> a ^ fc flET ? r -f ■> a > &#«-r- 
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7*/u£ JfM I" 5 r fc £-£tr r fc £ W fc + 6 6 5 
(cEf^fe, 

[!t#16 7] gjE&JItt, flfjE^-^»8SIJrofc 
fefciffl^f, fts^isscw 7. t> -y y zmtiftzms 

(i) HuEflS5fe^^T?'>*< fcfc-o»^7>-Kfc 
yintzubn^y b y fc, 

(ii) ^ft^^vKicati-ar^y^ K-f-fWI- 

*^ bT b8 ^ * + V 5 V ± fc> 2 O £D SI "5 ^ 5 x 

y h 'J k&*;<y<Dt.ib<o^y v y k^m-fh^v 

-7k. 

ffittxty y^n-mn^smx-mitctbiD^mm^y 
^»**t«L, fifrE<t#r^->3>'<7?-o&iiiRi- 
20 st»(^, fiET^r^^— >g ^^Sr^ffl-S^y 1 
•y^fc «:« *.& r fc t1-5W*JS l *fcfi l 2 ic 

E«W#!feo 

[W*JI6 8] WEtoSIl, 8»B^7 7^'^^ 
is*? hf^§ftfcBflE'1'^-^ ; Sr}ffiIi1"5^(-ffiffl 

^yWyv'i^ h£>#*tt, '>^<fcfci22fc, ftfe«^ 
77-f J/^ Tt-T-V^y- y^OSft^ 

fc^tr^^(-<t l ?EiiSft. ttft6«a*<, 
(j) SITISd-/^x^ hro»fft-tftb»«gt*:ft^ 
30 s^fy/i, 

(k) ^$ftfcSfJE^c75=§-*(co^-C, f^L— 

t^^T^&ftfcflliE^t-^^TrT^ 

7V^j6W1-5*x-;^fc, 
( l ) 7?r^ 7 , a±fflll(^ ESn5/57^y? zh/v 1 
h?js, "CT « t E S.ft 6 ^ 7 7 y y ^ * 

(mj J: 9 aWB** tfc»«-t % ±fllfc*dSftS 
/57o V-*"7' , y*y h fcTffi!ll-ia$ft5^y7-f y 

9 Y<Oy y y /^'7 3 y, XUt/X»±tt*«(*#KOT 

77^-^*7^^ hB?^y7'-'^3Vtr«t 
^^T^y'/fc, 
(n) U^/UT i>7- ->a >-r— 

(na) a*«*rt~E|I*ilfc, T«0!±«C1E^ 
W/5 7 yW7^x ^ KO^(i*fj6i-5 — =X 
so \mw.<r>^ l co u^/w, R tjf/Xtt 
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(nb) B1g«t*K0-~EK£ftfc, TWStf/Xlili 
\zMZKZ>7 7? * vt-t-f'S^f HBflMEKfct'JC't-S 
-OXti^CO^ 2 (73 W-i/t'Srflnx.SXX y . 

(o) ituE-f ^— ^rt«=g-f ^-fe/K-^L, a^f^-t 
/Hcii^^u^^T^T 1 a yf- 7"/wx-'s h- 
yicg-^-C, * y ? £zfc5£-r5*7 L y7''fc£fiH 

[li*JS6 9] itfiE^y 7° (j) tt> Bfr^Hlfiff 

(OiaWSfil^StSf^^ryT- (j a) 

5 ^ t zmm t-t m e a ^m®cD%&c 

[W*«7 0] ME*7y7° (1) fi^-fS^? 
7-f y9*7*Jx.9 b~m®-tZ£f$.fa%?Z$:J£t-Z 
f-T-XTy? (la) 

im.*?v? (m) *«, mt^-f^ty? (ui •?» 

x.9 hStf/XflTM-ESftS*?'^:** hWiaSrffl 

n-c, * y y eymnzznt s^x? ^ (m 

r) t«*.6ifct»«fci-*l»*9l8 8KBiiea* 20 

ft. 

[|ft*« 7 1 ] r y 7* ( n a ) *K TM- 

/Wi» mi&7'*7-V?° (1 a) •CfcJfcSftTt&J*** 

x., W77 4v9*y'sx-9 b«#*fi, **<'fcfc 
^»@ftg££^trj&»K± 9Ex£Sft, $f&6 8LS 

40 

(j) BrSroWTP. vt3iS£i-6«l 
(k) fc!£SftfcBfrEi2w£lt«&*K'^-c, flfrsai- 

mmftg. k ft 1 x m.-< <b ix rfc u , 

(1) 7*7^7Vj:±«M;:iaSft5?7 7-f y9*7'V 
(m) -?r«± 54Ii4«tlifc(l*lc, .tfl'IKKSftS so 



^7 7 4 y 9 ir7"=y^ 9bt TAKES ft % 
9*7**J* ^ HOiflSrffll^T* y y fv^fH^^Uff 
L, l^g|#fi<7)±MKEIB^ft5^77^y?*7'i? 
x* h&tf/XttT«MKESft5 77 7-i' y 9 
9 h<o?'J j/^-^gy, &0«/Xi±mSflS^roT 
flUKESft 5*7* v>x ? h atf/XliJtflllKESftS ^ 
77jy9 *7~i?x.9 b(0 9'J y-f*—P a >&£fiJc-f- 
Z>X7-y7't. 
(n) U-^A-T^TM^-i'a Vf-TVH-, 
(na) S1S®«ort--i2eSftfc < TfflO&O^ffllJKES 

lrou^/K &0*/X(± 

(nb) S*a«t^E«Sftfc. TW&Ot/XttJifll 
CESJi5^7 7^ y9*7~*J*9 F«Si:mt5 
-oxtt^Sicro^2ro^^Sp^5^r y7t. 

(o) **Y^7f ^±ro«-e?-fe/W£glcttU 
H^feSI- ilSafr * tV<— > s >7=— 7>ro 

t «:**.8rt 6S*#*l*fcH:l 2 CE* 

[W*17 4] ffiE^r y7* (m) iflOKESft 
5^77^ y9*1V*9 htT*!ltESft5^77^ 

«im«rtO±«at;T«ltESft6 9*77 jy? 
*7'Jx.9 b<09 V y7°/*-~*J b >i, BES^fiUjE^w 
T« * V » ft ±« I e E S ft 5 ^ 7 7 -f y ^ * ^ V x ^ h <D 

9 y »^-j>iyfctt*t5:twit«ii« 
a 7 3tcf2«©:m 

[if**7 5] WEsars*^*^ n±» #>rcs 

10 0 0 1 ] 

7 7 * y 9 ^m<o 7 * 9 mmm^co u v ? y >■ 

7^-^»7 ^-^E*SS*fctt7^i'E1gSntSr«ffl 
.Lftl/\ twiiftt^x? h • ^77-(^SSW 

[0002] 

[ffi5lE<Og»] (SfcA,^C0^-7'v : x^ h • ^-^ • ^9 
7^ y97. • v-^T-A-Cft, v ; *fc(iiHffi<75ifl)^-^ 

v!-/^7 7 «JM. ®fif, ?7'7 A V9 

i?*9 hiamm*. w-*sft. a^msft, 7u~a. 

^hrt*#ii*ft5„ -ftTc^yy-f y ^^«1p^. 
ttro^S?*^ KO^cfo^^'^x;!' Hi. f-^lc 

ftn, aa«»»-ett. r<*4'sfioTA>=t9X/* (p« 

inter's algorithm) J fc LT-Sjtt 6ftT^5 . ^ 



-/V*.? Hi, lk1i1k<0*7V*? h*>6*-fe¥W»5*- 

HSR#. 3-7.3-ry ■ 7^l:fiofc->- Jry-y^A-ft 

[0 0 0 3] rcoKffilcii. £*W(-2o«BgM!JSfc 
5„ JBlwlHJBtt. • * hTftcnl-^xcomm 

^(onm^v yy-t* • nr-t^mx-hz ^txh 

*s*5*»e>-cfo5. rrofcto, 7 u-a ■ t, hrii, a 

«ffi^flcff5 7V^A- T^-fe^ • (RAM) 

icftttSfta. ftMUE*?~-- y:?roii£\ &fi 

ftRAMtOfit±##K:£<ft'5, fflSttl 0 0M/-W h 

Hjrc*a. as 2 ansa, Mfcowim**'!^ y h d' 
y^-yyT*) ^rawi-^©^^*^ htiot 

Kft5, 

[0 0 0 4] 7c*c07i— A < * hTWR3SSrjEflB-T5 
fcftO*ft»lOi)S, WfyTjsy (banding) J CO 
tefflT-feS. ^yr-f v-^Srteffl-fS^cii, -Nf|c7 
u-a ■ x h7«-«Bfc*iti4M*y fttcfffi-f 5o tffili 
^Mty^s;!' HO-r^TiJS, r«^!J^ 

li^^liJ-.IEtlellSlcU'^yy y^^ix* 

as, .frffi-f* y is- J* - * h TnmftWM*^ > t> 
(u-y^yy;/) UJ:5t + SH«^'f^h (wy*'!/ 

Ibf^tt, fHy/j 77h£*i6 0 *7 
hoi-^xtfffimztilz®^, • x YT<r>U% 

£, (SfcfifficofeE) KJ&D, 7y-A-x 

hannttisfi, imh (^KrfciciH) s& 

W § tift tfft (i * 6 ft K '< y KO^ASiS iSfcoh 
[0 0 0 5] l^<O7j>C0<i!lC0:/7 7'f ;y7 ■ •y^fAt ! 

ii, ***y • 7f y©lS-eWfc!W*W3*i5. 

7>f>iSit5t^x? MSffiMP(f£co«gT-;t-7*-y 
<Dm$f<n?-s<-ytf, 7-fy ■ 7, hrtty h $ti6„ Cl 

coast, *s«7u-a • * hrcoRgssr^flR-rs 

[0006] ;ixferoa*»i^, *:§i^7y— a • * hr 
coraSiiaticoraigroW^Sr^-rsKifejiSfcs,, ^ 
co± 5ftSffiwiot?li. g-x^-yy • 9-f y*s Ji#(c 
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A^its. ^ii*), ®mzM*y¥*-v b<D-t<<x 

i\ m^'J * H^flM^nS. ^-x^y • 

(i, ^COX^r-yy • 7-fyi$St5t7'^? hcoffl 

^cox*^ y ■ 7i , y±rro«-jfetft5^7 , ^x^ hffi 

ftSfflcottco^ftmco^T-, SSjcoat JJcrojaroftl^ 
io fc5=S-H^cofe7 f -?AS, TtTi?- 7 7^Wt5 
®MIte^y^-^Srf£ffl LT, irro«J6W(tasftt± 

ofcujgt-siati. sm$tis D iwu^t. iacoy^ 

H^flf$ti5. 

[0 0 0 7 ] rcDR'&ti, 7I/-A • hTSfcliTW 
20 y.^hTASft<, ±^i9ASft<, jSr^cNfS C:WNIi 
fi^lifico^) T-ttft<^»fiicroB#p B 1-t'^y-ya;^ h 

[0008] 

TBwtKftoMliRASfoS. 

[000 9 ] ( i ) rooSSfefi, h<T> 

&-<«&J ft»U«B!J«tt*:*#-h-r5. *^cro^7 

30 ^y^-j &8tU&f}iJte > rcogfe(iJ:oTf-/i<- 
ftv\ 

[ooio] ( i i ) iw4aiiU£tftfmwK?ra-? 
6„ s-^^ + y- 7-fyiT'iay^h^B^-h ■ 

7* — X- 7— h (brute-force sort) £ glfr*" 5 - £ 

[0011] ( i i i ) - <7>&mt, -ft? x-9 v ■ ^ 
^HTB7?^ (Wm^-x) Wtl^f-^-hLft 
v\ ^coi 5ftW«(i, !iaw^77 -f j/MEit* 
40 gro&gHJjtffi-efca. 

[0012] ( i v) croeisfeii, h^tLSH^- 

h©feMBSfefflt5 7**iSg£lf#-hLft 
i/\ rcoi 54»»'fctt, xoR^-K-etofflWSfcii 

co^M^ |J. (5 £ A/ if / 7 7 -f 7 ^ 

so [0013] (v) rcoazfcfi, lo^rtii^co^y 



(11) 
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f v^tt, (a hh¥<r>777 * vtm^%<r>&WMZ 
[0014] (v ; ) -©stex-ii, ityo^ hwia 

[0015] (vi i) v<oi>m^ 

ld N lO^fclllicro^-yv 5 ^^ hroT77 -f t?7M # 

[0016] znmm, ®tft<n?7 7j ■ytfZiUm® 

[0 0 17] ®.ft<Dts>yV ■ 4 VV-7 

9 , W&,<»7 77 ■< yV ■ h<Dfe<DTA-7T 

«^*^ (an*. ^aw**fcttv» 

fc«-5<H**©*KMMti-6fc«>ti**. st,&<oa 

[0 0 18] 

[0 0 19] #3S9]w-o<7jJ®13H;i,J:fttf, 7*?-W 
t-V&f&lfttZ^K, ?77 4 y9*-7~*J*9 h 

ttSSISW* -V 1' >"<7)fc feroMfSi- 

y 7 <ntz 5 saxufflfcifc 5 1 <o 

gi/^?? ic»ftL, Jiff tttt «iBg^*aa^«ia =■ 

3 /< y ^ r ic *N>T*?*6;fc 3 /< v 7 7 

^7?7t, fl5ffi^2&Ut|g3/<y7 7*»e>Wiai'= I - 

[0020] **wroteroW*fc:**itf, ^57 



»n 2 0 0 0 - 1 
20 



9 0 3 



\-<omtffi&7Xi>-wm<( *-i?<n%&<r>x 
**y7 4 viro^iollf^tSS 1 &a£« 

ts7--/\<t*mx-, ffiufimfr, (a) miiasawiai- 

3- K<DlWE:fe»#fcO<* tf/HR»©#* 1 © 

s/^t, (b) B1j|a7^^ilI*>II-*3^-Cfttffi;^fI^ 

* x -f ym u 3 - K <7Mt£ JttS-t 6 ^ x v 7° t . 

(c) OTESWEwawa- Ktr, M1Eltttro^*+^9 
20 y<Dlzfr<Dttfc1-Z>me>mX'-gi%ii-ZX'Ty7'b. 

(d) Mff^l^7ii7Jro^iSrfIE7'-/^'rt»fflWfe&)*v^ 

fB7*-/K^»ja<73li±»?/h$V>^(C, (da) SfllHS 
Sr$ttfcmffiWi22U=>~ K0Sffcft«>jZ2 ^ - KW^ tf/U 
95»^iSe>ix, (db) (dba)*/J> 

Wiai'="- K«>±«|5^ro»Ol'=«-K-^a&iT.. (db 
b) itfJKKfT^fcffli^-Kli. ffita-yxT-yy 
(dba) -e»c*ofcME:A-*rou = -K~i£& 

30 ^ (dc) setesaii'=- k*5. ateojaw=-K« 

^fcT^x-f ^fflu=>- K-N&fbft, (e) WIET'-zl' 

(b) »s (d) mvm-fxTyT-t, ^4x(cJ;^-r 
BfriE7°-/i'OS/hroaiii:i^='- K^HUlB^jffioia^a- 

Kroflfffa±as^iSSb^ (f) wlU^(OU=-~ K<7) 
itroi'a- K^JEif^^StT-Hdia^r- ?7 (b) 75 

m (e) isu, i*:^-c% sftfa^"-/i'A>e>ww3'- 

40 3-K^77r7it5^7y7 , t, (g) ftfllEVa- 

yT'i, ( i) HfllE7^^W^-1'^-v : ©K^SXdr^ 
yy-^Wft+KHLt, flfllE^7r-yy (a) TiS 
(h) *H 9 B+^^y^i: **BB*Sft 

[0021I *fc, **W<o«tro*«^J:ixtf. 7*9 

50 ^ h^^ai-sKBr-fo^r, ^*aatt, -7^^?-<x 
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y 9 9 hOBIII^KMfffc'NIKU «««>^ 

>y 4 y <Dtz#><D&3UZ BB1" fci2£iH6 -5 
Wf*)oT, *S?Jro!S 1 '< y 7 7 , ^2><y77» 
Ot^3/-5y7 7%W-t-5/^ y PS^^fcicrotoa* 
ft £52 u- = - K fcHSfftttt $ hTV^ 1/ ^UW, l'<y7 

SlXy77 CJDAbnwt* CTMSfl^tt^TttftflWB 
iQ V = - K * if it ft fcW* tc 2 /< y 7 7 ~ iS 5 , 

T3fe'<2.fcfei-SS3^y7 7'-i* l 5, fflfef&2&T>*Sg 
3 /< y 7 7 A» <b w - K SrilKWfcteS L , fttto 

■fe y f- <t x zwrnmrr- £ ft2><, 

[0 0 2 2] *fc, *»W<Oft<o«*tJ:ixtf. 9^^ 
-B*^/«-5?*»«i-*'<<. /77-f^^ 

9 HSriaa-ragg-efoox, sa&ai*, 7**7-rx 

^i-*inw3-K*fHlii-5.-tfc±9, WE^97-f 

jftttt * nr v >4v »» 1 ^< f 7 t eft* u JWWtrt w 

ffi^toa^froKl' 3 - K^fjfE^l/<y7 7lCliBx.6n 
CT . «ff Wtt «fi£4 mffiffl v*-y £«ftk: 

2 ✓< ■> 7 7 t . *#f<w -e* ft V*fc 

[0 0 2 3] *^»{tii»^l-±n(±', 5** 

ftfc^Hfctsttsm&w* >7i' y<nlz#><r>M& 
■f*iai'='-K*rffm-6rtK:J:9, JtfJlE ^ 7 7 ^ y 
9^y^^9 hcoffl^w^HW^IWL, 

52 v =1 - K£ «HJ¥tt it * v ^ft v ^ l /< y 7 r l-<£J$ 

7 7i^px.e>^w(oci:T, H)?wit^r«gftmiaiaw3 

- ViWl £ft fcJiftKJS 2^'777-i5ft^7'/7- 
«5a-Ki:, Hi/fi't(t-C'#ftV^a^W5flS:, S53/*y 
7 7(-*J^t^'<5fc«>(-K^3^y 77~->£S6i£* 
Ki. lffiE«l2At«R3/<y7r*»6»ai 

1- * 36 -< ib tt fc£g£9«rr 5 r y 7° » =■ - K t 



[0 0 24] *3gWWJ5f-flfero«§«tt«T»lftW*^W 
6»^tft-5o 
[0 0 2 5 ] 

[Si] 



[A\ & l a j -e^bu 

7 £A~ "T?^fc>U 



£>eyf„ derive & (Destructive) t^t>T 
gift, aybfa-y- • C770? ■ MI 
|iBi/^ y y^*3it) ! 7" >"7— ->3 yrofcfc^S 

20 X-^D (RAM) 3(CMii-f2>*^ h • 7*Ptyt 

->X7ARAM3iai, ^*p»ttro^-K 
••TV** • K7-Y7*5*fcl4Sia»^ffit, J?l6tt» 

tt, ->Xf- jURSITffl^* !) (ROM) 6 ttStl, f 
X7AROM6 (±» ii«f»i^MH$ROM7 &aS«ISi:L, 

ay/<n'7^?IS (CD-RO 
M) 8 KlJ: oTl*J£i-5 C t 6. v-^T^Alic 
«, y^^atBfM-fttrf^SvKK (vdu) *fc 

30 ^.Jitf - * 5 "C*# 5„ 

[0 0 2 6 ] -y^T^Al^MLTi-ClftilLfc^®* 

ti, • v^^A9ft^L-cffii:saais*i, ibm 

PC/AT i>^7 r <Oy<~-Ui-^- al'ta-^iW 
Lfc^fiSc, Sun Sparcstatio 

[0 0 2 7 ] ^tt5iau-ia^$^rv>5 J;?ic, 
y?y yymmz oi± N ii^i±*^RAM^e>^^ 

[00 28] 9:(Cia2^#!fi-5t. £4 U^Jt^fi 
(0|fffi7 ; -^i5lttiEl^^$tiT^5„ H 2 coHfigitniil 
60 (4, 3-7v^? h • y^SEKEl 1 5. 
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lOt^i? H • /77^ y^ESEl K4, *7 h • 
-fv-ty?-2izi:vX$Lf&,£h5,fi\ S.O/X(4. 
fAR AM 3 rt(C|E1t£ft£7^*^AROM6 7)>e>j£ 

h • 7~y7 4 ■yPW&i lKli. r^r ^TVi^ro 1 & 
(4, ^g^rSltf-rs^^Hc-^Si^&m-rottl^gg 

nflrtt?v>^y ^^-ctsi 5(ci-s^<^*>ro^?.* 
^^adt^-e^a,, HK*:/7^^gHati*Afro 

ZfrSiftco?-? • 7*—* v h&«ffl1"5 - t fCS 

$„ ^'v 5 ^^ mc(4, #^<oji&5>22^:/ro*g-a« 

aft, t-<-CB7*-vy Mr. 

w^t^coigssy^t?*,^ , m&i*, 

^ • yjy&^Z.iXm^fts Lfci^t, ^ro 
[0 0 2 9] fcitll 01 6At, S^*®aic|H«l! 

b, us?*) yf-t stable, 2onW6 0ifcW 

6 0 2K#t<l + 3&g#fc3j2 6 0 0<7)$*t£fifWffliE 

tfS, -&&Zftl,X®m^W.£h,Z>A\ ^ft£6 0 4 

6 0 0(4, ZtlZ'tlfcfi.e 0 3*3^6 0 4 Sfc(4**,6, 
6 0 4fc<fct7 : 6 0 5 ZH-fb 2o«giJ*OTi2 t LX&t> 
ftfc 116BC, M6 1 l*5j;TJ<6 1 2 fcffl»^6 
1 3io<fcUt6 1 4(cio-CIEiE$n5=^^7"9-f>-6 

[0 0 3 0] H16Cfc, ^SLV^Jgiff^lCiSfflBltg 
fcfflrofl**-*-. iBtt, *-<o 

38flct*/fSix, i&g-e&tU*, vj/HT? 

[0 0 3 1 1 HI 6CW£«C:(4, • 7-f XA 

(4, star t_x, star t_y, jaro&»$#£ 
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i26 2 0(4, 3o«7fy7 , iS», lon^n/Uft 

ry7"»Sli. x^fy^iy^f^i* 
i: L-C5S^$4x5o i*»3o©^T5'7 , i 
#ro»£\ $#EiE(4 [0, 2] , [+2, 2] fciO 5 
[+2, 0] -C&5. x*T yT'ttttfft WtfCfc 9 , 
-ft,(;:4:oT7T;y7rofr#;i^£fr-5^, y^ryT* 
ffi(4, &-f, *=*--W ■ 5^ ^roH^^S?** ■ 7 

\\ iffcroH^tt, ISI±'<7^-? star t_x, s 
t a r t_y, finis h_yHi.XIW.Pt (DX) £ 

^nt-rs^? r-A-iUft-efoSo rrotaj-ete, 

$##526 ZOn^mmX-h^bs star t_x 
*5j:tfs t a r t_y(4, 8il»i»»!0»5>4 g 

H-f5rt*st?#5. ffltttf (DX) (4. ^-tWtT'fc 

• 7 << y<Dx1g.%$-Z-> ®jS<O0ljT*(±. DX = + 

*H5 2Pg<i (ddx) t*+a. 

[0 0 3 2 ] ■l9Cfl3*«|W»»tt. ff*LV»«fc» 

(73 3 PgflS (DDDX) *Sji*D$^T^So 

[0 0 3 3 ] ±B*»b, fflW^SrEiB-rs^WT 1 '- 
30 9 • 7*- -y htr«ai-6(fi*#*>6fc. WftftHH 

[0 0 3 4] #*U^ffiJg1®«fttfs«:, i3 8fc^S^ 

40 ±(cv-v^ y v^n, r.^(cio-cs*^9 o«r^^ 

*»b*>a»5 *73iH59 0(C(4, S*roSM4S 

(x) t^^^v ■ 74v\m. (y) roPfl-e^&Sftfc 

i»i29 2, 9 4, 9 6*5 it/ 9 8 7)S^*tt5, 522 9 6 

^-7-^^^ HiE^I4, H9 Alc*$nTV^5 < t5lC, M 
05522 9 2*J±0«9 4^lt(Cii<J< t«tt5;t«t 

i*itBBatLr, 39 2(4, mmm (40, 3 
50 5) antes'), 7^^7JiSiT'iisroT«'--5fio t T, m 
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HSffigUO, 1 0 5) X-mfrS. HHUfC, 523 9 4(4, 
Blfil (1 6 0, 3 5) frbHW. ( 1 6 0 , 1 0 5) 

ft*i/7 7-f y9 ■ 9 Y 9 0® 

*¥S5#(4, mm9 2ri>6i229 4~7**ffc£ftitff2 

-c-jfeSEl-a:: tcio-c}|5;i:^5„ 

[0 0 3 5] Ld»U ffl^Hft^cod-T'i^ * H80 
(4, 3<5C)t^x^ hi28 2, 84i3j:U!8 6t;io 

•t£fg£tu £522(4, Hftwrow^ten+S'** 
h&ttZinZ. 522 8 2*540*8 414, SfSffiS do 

o, 20) ^bi&so, ztiz'timmm (no, 9 

0) *fc(4 ( 3 0, 9 0) S-CgtfS,, 52 8 614, Zfl 
b 2 owii^&erorat 1 , ft 7 * * fc£ ixfc£a»f> 
*r--ro*-l6)(C®0So rro#S»«SJX'i4, 522 8 6 t>\ _h 
-Ci$'<fcj2 9 6*340*9 8 i: ISl^CTK^rot?, 386 
tfS£g$;h-5rif4!&S-CttftV% £^5WI4. 522 8 6 
fl*, 522 8 2*540*8 4Mt5M*t-oi^5Wi 
fc5A»bT?foS. 5228 2*54 0<8 4»!Ej£i;:teffl£;ft3 

r ©*^t?f4*H^n+ 1 *fct4- i <r>mmm 

[0 0 3 61 01Ot, 7-YV3 5-e*fe*5 

ft^9 0# wvy y 522 8 2*>40 : 

8 4 7)***+ V ■ 7i*V3 5 <fc<fc'<D4 5le:£M-r5rt i £ 

iaiOA»e>, Mfe7 8 <r)7Afmztt x ifV^^t 

|t2oWt^x^ b 9 0*540*8 0^fi6W$n5.£. 

®«fo.5^t/4 5 ^ii>5 0 zti&mi i c:*i\ mi i 

(4, ®®7 8<73Uyyyy;/K&ffl£;h,5ffl!;*h • U- 
K&J^-f @i?*>5. 01 K(c(4, 2f-7*v* 

s^hriciofow, 2 ow«i^^-itis„ :n 

$h5„ Ell 1^6, 522 Kro-tn-Pil**, 

[o 0 3 7] SO*E!2tMoTlWt;5o uvyj^ 
?£S£BiJLfc»-C?, 1(4, 

y* n^Ty/i 2&mni-z>. 

[0 0 3 8] **!>^h^dtl 214, JfctM'Nt'bftfcR 
OM6iQ4t/RAM3Sr^-r5*^ h • ^Ptyt2± 
X-n'il &*l5 V7 h ii7 • ■^a— yi>2: LTHJS^ti 
U\ ^*y * h£(&l 2T-I4, ^»<?)^ 
77-f ^lEizSSli, ^77^ y9 ■ 

lo4tf4lfcT-g^$ixfc^7'v ! i ; 5' h • 7=77 4 -y 

9 iE5^*a* y * h we** 6o a* y * h b. 

i4, s^y * h • * br 1 3 **y * 



h • * [-T 1 3(4, -)Kl-RAM4rtT-^fSStl6^, 

2rfcT-#5„ H 3 6 4 51;:. y * h • * h 

71 3!C(4, *ftro«J«S#*:^»Sri:AS-e*. 

ioi4^^ h y-A i 4 -c-fot), 1 5 1 o(4i22tf m 1 

5-C-fet), 7^?i«ISr-?16*tK)5;t« 
[0 0 3 9 ] ifr^* hy-Al 4(C(4, ftfeiomfoftX- 

mmzhz>'&fe<oy : 7 7 4 -y9 ■ *-fVx.9 bzu^y 

-K***ii*. 0 8(c^$HfcPI^£O0ijT(4, 

(D x^r-ty • 7-r ^2 o*-e^y^y v^i-<5 (or 

(2) + y • 7-Y^2 0T*2oW#!/>i2 8 2*5405 
8 4 Sr 56*1-5 

(3) ^ + y'7^y3 5if^!)>m 

(4) X*\y • y-i >-3 5 T 2 0(0*^522 9 2*540-* 
20 9 4 Sr5l*Pt-5 

(5) it^s-euy^y v^-r5 0 

[0 04 0 l», HI 8 (O^JIC 4^.(4, aif^i5t 
(4, TKas-&*ft*>r<kfc/.e5. 

• 522 8 4 (4Hlg{5i:g 1 0 0 frhWH 0 , 522 8 2 ttH^ffi 
gl 00*^*6*5 ; 

• 522 9 2 ttiUtfeg 4 0j)>5>«*!1 > 522 9 4 (4B^fS:{S 
1 6 0 5 ; 

• 5228 4(4 7 0**+^ • 7-f yfd'ltlSO 5 , 5228 2 14 7 

o^df-rv • 7-f yfcimvz ; 

30 ■ 522 8 4 (4<B$ = -1 Sr-frU 522 8 414fR#4=+ 1 
t5 ; 

• 522 9 2(4ffi#4=0^rWL, 522 9 4(4^ = 0^^1" 
5 ; 

• 522 9 2*3 40*9 4(4 7 0 7,^^y • 7-T ytitimxf 
5. 

[0 0 4 1 ] ±»*^^ h JJ-A1 4*54 0 522t»^l 5 

(4, mmiiLM (x) t**^y- ?<<ym (y) ,c±o 

[0 0 4 2 ] H8(C(4, y *9m<mm=r- 9 
•f, L-fc^'ot, «^y 7. V 1 3(DfatSW^l 6IC(4fBI 
fciE181-5 sfi!.Si4 s 4V\ - ro!l*^t^r:ov^T (4^-CUiW1- 

[0 0 4 3 ] «*y ^. H • * hX i 3(4, iBPffv—^V 
y\,u- uy?y yymB.2 O^Xixm^btiZ, 
mmis-tryu**- uyyjy9'ms.2 0(4, 51^(4 
»«[al8Si: Lt3iJfe$tL5 0 mm*y->r y i/^/u ■ yy 

so yy>^gg2 0(4, «^y^ hSr7^^u^»^ h y 



-A(c^&L, C<£>* h y- A(4. tz.t7UiS.-fys 9 . 
t=V */c(4>^y • hTfcifcJE'Jroggde 

[0 0 4 4] ff*U*«*tt-ett, L-CB 
-/HI, ^i'glSfcli^^^-^ ■ 

[0045] E3(4, m% ^>yj>- 
?mwz o, h • * hr i 3*5io ! -s#fi<ji'>' 

yy ■ ^ 3 o©«j££*l-ii-c i fc3. 

(11(4, ***ffWft3 0 0, aMt'^-'MOO, 

yueoo, nist-a-i** -^7 o Q&zvmgmti'e 

^h-^hT13tlS)-Ogffi 

RAM) Sr*fflt5*\ j£«*aHfc«fc» 

5„ ifltea*-^*— ^4 o o t4, iau-a- k • t, bra 

2&<£fflLT, 7* ^A 1 + V- US 

0 OH, ^S^fefe"^^^-^/^ 

^6 0 0tt, HtS L 7 s — 9 -T-^aeML 

(4, H^-g-fiK^^ 3 8£$fflL-T, ffi73@ifl«<D|I£ 

[0 0 4 6) SiU^l-^ F71 3*3iO ! Ji-Cf^li& 
'^Lfcifero^ l>T3 2&V>L 3 814, RAMrtf^It 

[0047] ®3<o&wm^£tiitimxTv7 
(4, M'^^7^^22©i*t5. cros-e-, '<-f 

;tiif§, _hjjfc*aai4, T^^a-^^W^ y-fe 
- -^co&afe %Tf 5 * -x? * Wr $ ft 6 . 

[0048] ^SfTii3O0(l, KZHI-AI 50 
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4rt>?>fft#£!7t*.®'9, ML, tro^Sr. (±1733 9 
8 £r#LT'<'l'7' , 7'1 r >"2 2rt«tn ; &i?a-/l'4 0 
0, 5 0 0, 6 0 0*54^7 0 0(£$5i££;ft-5; < yfc— 

M-Ai 4(c, «T«*<nttft5:ii i 'C^5„ 
[0 0 4 9 ] LOAD P R I OR I TY PROPE 

rt i es : rco^tis m^mim^x^u^ 

-7>3 4 lip-h'JMr-^i, Wf-9-frv- 
KSh6f-7*^»7 Ku^(cMiS1-5, 
«300li. rro^ta^ot^lt, AEftUffiWttJs 

4t>'*tfiiT-7'^3 4<7>JiS$^fdifif»7 :? -^OiE 

m.<ntz.ib<D * yte~i?%&ftiTZ>o r*U4, ^wr-^ 
^tt^yt-i>*7t-7yM, Mi^-f/y-O 
2 2&3TLT, * hTtW£^frS@ftl«{£fc£^ 
3.-/1/5 0 0(cSt^tl-±oT»^T?#5. 

[0050] LOAD F I L L D ATA: CWA 

^■14, mmLf-f • 6 (CP- YZtlZT- 

9t> Wf—f&B- H'&tuST^-^/i/rtWT K^* 
KBBSrt-S. 3 0 0(4, i<o*-frtU^-3 

[0 0 5 1 ] LOAD N EW EDGE S AND 

RENDE R : rro# < p-(4, ^OX^-r y • ,7-f 

t^ffli 5ro«*y* h • * h7i 3rtcor Ku^teBB 
il-fS. ^^^tH*3 0 0(4, rro^^-(cffi^ofc«F 
(c, rror— ^^r^tf^ y*— 5?&7>— ht, ffl 

jo-a^^a— /U4 o o(cja-f„ a*aa^i ;! 3.->'i'4 o o 

(4, SfL^iaWT Kf^*ia^='- K ' * H^3 2(dffi 
ttS-fS. ffiS^tifcr KU*Kfc55a(4. 

(4, ffl(4, s^y^ H^^aai 2(-4ory-h§n 
5o SUw*JS^fi8-e(4, ifl(4, Bff-^^-^t*- v 
^yy^gI20l:±oT>'-hSti5. 

[0052] SET SCAN L I NE LENGT 

H: rro^-^14, y V^frS*^-^ • 7-C 

*3oo(4, ^w^(cffi^ofcn#(i, r«ffl^ia«ia 

0 0j8j:OW****f 0 0« 

■f. 

[0 0 53 ] S E T O P A C I T Y MODE : r 

5*»t*i-7 9^KiBB5tt8. **«f«« 3 0 0 14. 
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[00 54] fif$nn®M3 o oi4, asm, 

[0055] • 71" vrou'V^y > ^Kit^f © 

fcK9j-*-<5. • 7-1" >-«uv^y ^?<Dltib<D 

T'S>5r.i:-C'foS„ :W3oioy^ hW^-fit^Sfc 

ttl-^rjisg-efeiv^ rit^y* M4, iaft«i5 

^b»#^LOAD_NEW_EDGES_AND_ 
RENDER.^Cioffey h£*i-5trU^i22£#tr 

#nay* m 0 2, Bfr<o** + v- 7-o?j»e>«s^ic 
iitf^fc5a^="-K*-&tf±jay^h4 0 4tJ±a!, 

- KSr^tf* tfyujfly * h4 0 6 7*4. #iau = -h* 
tell, TTB*ft**l»6. 

[0 0 5 6] ( i) ?ife07.*+V • y4V*mm$k 20 

(* JMWe BXMilH-6) 

(i O £©a©llfi©»» . 
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(i i i) + 7-fy»8t:J)ai/3- KW 

(i v) • 7-Y XOlfcXZ.tojQ.V^— KWD 

Xfc;!lll*S*l6tt (*flitt?liDDXtlW5) 
(v) lo*fcttttft»tffcJi{fc#* (p) 
(v i) a****;'?* V4±l*i# ( + ) 
*»TI61# (-) tSJSII-* A>fe«i-*iai (DIR) 79 

(vii) !)^H^»Ml^wrFl/^ (AD 
D) . 

[0057] :»i9ii7t-? y M4, ^ h/K B 

5 = 6 J: 5 14 5. Hflc<5? 

^<o^©f£ffl#IfT'f4, 8 Ft* 
«5S (t4t"t>DDDDDDX*-i?) tfS&SKfcSS-g- 

[0058] H8<7)iZ2 8 4 *J it/ 9 4 »0tj T?(4, 
> • 7-f> 2 0t"05^-f Siaun-KiJS, JKTW^l 

[0 0 5 9 ] 
[*2] 



ADD = (irrelevant in this example) 

[0060] u^yy/MKioT 

gSftfc 0(0 fit-trow 3- K^^Sn5r.t^*T*L 

8lT-*)5„ 3o»M H40 2, 404*^^4060 40 
Wft©l'='-Kl± < • 7^ (X) Jffi 

fiSrolGi-eKg£ft5„ r*U4, iIS(4, SSJiiiaA*^ 

t#6>ft, iaA7J^i^-A>4 0 8(4, mftn&sts/y 
t-y***SWflMl3 0 0i4»6«rt*«. + 

fls 6 *i 5 S /h *i 4 Xfgc * ro X Jtii I c t 7 >- 7" 3 *i 5 £ h- 
ti-tz.k^&iXZhX.-J-- hSr««+ar tASBTteT 50 



ii^ **-8-iC(4, 52X7^^-/1-4 0 8(4, > 
y-fe-i?^, ttJ73 4 9 S&tTLT^-TT"^^ 2(75T 
SOT-^-Zl'SOO, 6 0 0&£tI7 0 OlCgttjg 

-To 

[0 0 6 1 ] fflATJ^^^-^4 0 8li,.3ooy^h 
4 0 2, 4 o 4jsitM o 6 ro^ftm^ro^fciltf* 

#fia»**L-e*u4, ^ • y << v<r>i&m<r)mm 

(c, hrtroft&roffl£#K1-6 4 7 
4x5. *ro$, iaA73 ; &v ; ^-/i'4 0 8(4, igftStiS 
K*s 3oro#Hg$ti5 i^=>- Ka>P>rofc/hroxffi 
aSr^-rstrofifeSJ:?^, 3 oro#$ Sftfcffl ^ 

33^, *ffS"t-5i22«H^ x TSErojB-ctbTjSftS. * 
rou3-Kro»RlcffifflSnfc#BRtt, -troy 
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A- 4 1 OlcjUfettSo $fc, 3awv»<oA>»7-f— /I' 
fl, fflMS^ v^ — A- 4 0 0 <Dtht>4 9 8 t LTiSftm 

[0 0 6 2] ja*Stt®ofc^F(C, ialff^e v 5 ^-— ^4 
hSr?*^ 1) ^ >-M"5. ^(DAVy h^otcilLfcii-g- io 

•rli«»*KfrB6. »#-ett* TEWBtShS. 

(i) »»*r«*«-a*:««l!:«aE®X*mcap*S*i 
affi 

(ii) *-£>S220)$TU>DXffi 

( i i i ) *(7>iaro*rU>DDX« 

( i v) STLV^*S)K< X^Y V • 7^ V&W&tL^ 

[0 0 6 3] ^£ftfcT Y \s *\Z.®.m-^W£#.<r>%kfttt 

^cofflid^L-t^-^jyiW^aii^T^ 20 
ftfcv. ^T-ftv^-fcli, iaHSSr*^-^4 l 0 
tt, ^roffleofc©*^:-' ■ 5-f ^roxfls* 
a„ asm* afewxffi^srto, r.ntD 

XljtSriPSE-t-5^i/!)Sfflv>?>H5„ DXIi, HLSSfta 

^•&7)Sfc2>o 32211, 1S»«j22W3- KroEJU'C 

fe a3227"-A< 4 1 2l*3«{£ffl »JWj:^#*t3 y Mc#£ 

-/U4 10tt, ^bj MM£ffl*rBBKfcaro&fto„ 322 

^322 7-^4 1 2(cS#ii*4xt*&«, 322 S 30 
ff^^-"^ 1 Oil, SfL 1/^3217'-^ 4 1 2(Cii 
£p£ftfc;i<t£, tf-i§*4 1 6*^LTi22ffl^*y ; ^-- 
/u-4 1 4 e>-£5„ 

[0 0 6 4] 7-f ynisv?)) >>y<otzib<o 

Wttttlt, 3221^73* ^a-/V4 14 tt, I341CI4 
H^ft-CV^^, i2JW=i- K3 2rtwy * h 4 0 4 
fc-iy4 0 6 tcBiili-5*±322 y * M 2 0*3«fcl>qfc* 
t°;U322 !)^b 4 2 2 ro-tfrft' tl—ro#SSS: ; fr-t"5 0 -ft 
bn&mcoZiiZtu*, S^fiSwyxW 2 0*>±o< 
4 2 2*J«»*ix5ttllK«)JWil9;SSix5. 322^3227- 40 
*4 i 2t3g»P*tLfcr.i:Sr^i-«^-4 l 6£gl7l&o 
fcB#lc, 322tti^- ; ev 5 ^-^4 14B, mto£ft,fc.mt>K 
&±322 y* h 4 2 0K£$K*#&*4xfc522 (^fcn 
If) J:0/hS^XSE««:*r-f r 

«322&±322 y * M 0 4<75*Jif;Lilfltf- a d tiS-C-^/jC 
322 y * h 4 2 2 Srffi^-rS^T-, fc^322 U * h 4 2 
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o*»roH«»«X'tt, xtv^ te4SSic:*£^x&&ft 
if, {fcro&fHCfcoT by #JJi5Wfc5. 
[0 0 6 5 ] 3227— /l' 4 1 2 l^jiJP^tbfcffld^ &±3fl 
y* M2 0(C®^(C##ii*Kfc322 (^fott(f) a± 
roX&SSr^TU 3227-/1-4 1 2 
y iflffi/J^v^-A^ 1 4(1, 3227" 

-yi/4 12*>t), SvhcQXMIf ^-f-aiflSritlRU -t 
C5322*»:±322 y^l-4 2 0CO*mi-iiADL, :«Mt' 
ft±322 y^ M 2 0*Si6fti-5» 3227°-/!- 4 1 2^W, 
-troiaKi-oTfifcfeift/t^fc^n;, Ml, ££i:LT 

[0 06 6] iflA^v i ^-^4 0 8tt 1 ;^f>30» 

x^y^S 4 0 2, 4 o 4 fcotrM o aw-t^ta^-*- 

U *<D* s/-fe-^fc. «ft«MtftS*^»-^5 0 0 
t322SSf*^=»-— ^4 i 0 (Dpsj^CiSS, *ro>y-fe— 
•^SrSl+JttofcWl^, 322 JE 8?*-^:* -A- 4 1 0 H, ^ti 

•e©S> r. »t< y^-^fciflfflT^v 5 ;*.-^ 1 4KK 

1 4li, 3227-^4 1 2frb<Df& *}nm^^ — 
K©-t^X^> XH-e^ro±322 y ^ h4 0 4(d#tii 
tf. Jk±322 y ^ h 4 2 0*5ctT/±322 y ^ M 0 

4-cO#Wfe, 322 A* ^^^-^4 0 8 tiZJttlA'E-^a 
-/i'4i4roWeS»t, IBI#«9SEl**r. ^^tf/ui22y 
7. h 4 2 2 fc*fcT/H22y * b40 6 IC 1 L T t 
a. w<7)7#T?, iJtO^* t y • 7 -< y Wfc 

#s«t#£*ia. 

[0 0 6 7 ] 322 1^3- K»fflA^f(-»C^f ^322 y ^ K4 
2 2&V- M-ao-C-llfjK , j er<D±5 7 , i522 W3-K 
#ty 7s V 4 2 2»*^(C3i*Pi-ar ^ 

tK>3E*roHtnc:y-h$nay^h4 2 2(±, ^ro^-^ 

Y v • 9-f y<7>3227^^{bT'T*"7 : '^7(c/j:5„ 

y^ h^feffli-ar.2: i!>sx'#, *fc, S45v-i>-r 

zv j'j sr^ffl-ra w t tf-ct a 0 
[0068] Jtia*»e>» m&m* vm-v&. t-^^v 
■ ?4ism»i.xm*M (-*-#*>*>, sfYt-y-hS 

n, ?fcicxTy-h*^a) x^ifi^^-^^-^ 

5 0 OirSlfe^ar 2r> fc-it/frfflSSSI^ y-fe-^tc, 

«is&i-ar tfls-esa. 

[0069] I12AIJ, 3220«|^?55g(t^lbnaB#(c: 
322^9^ 0 Ollio-r^^tLa^ffitt^fo 
57^f^ 7322 K4 1 8 W^flcW^ffltitSr^-tll 
Xfoa. 322 COitttCO^^SX y-y-f (E3E) ^T'foa 
»-&<Cf±, 322WXffl^, ft&]<7>i&#ff) rx^r-y7j t 



tU4, ffL^fflu^- h"<nmfiK x..,. + x.,.,|:J;o 
X V - F £ ft 4 tf fttfft b ft n i 4 5. Lfc # 

fc*tot»4tfHtffte.ftv». y»4. r 

9*r ^-/'mv^ — K4 1 8 »NY7^- /UKfcP— F'S 
ft 5. T^r ^MWDX^-f^Kli. ^ FA-£ 

fci±3M«DX7^-* K«aij-^a»e>=i f-£ft, 

*^y:/i&#©i§&K:f40;OS-fes/ F£ft3. @12Aic 
*Jtlfcu77^ iS^s±lSl* (01 3 AKBIig-f 
5KW*r#J«SftfcvO T-fc 5 y F q 

7 »»#-W»»»«*lclry F£ft. 

ft^^tBHTSM. i 7 ift 
(4, m^ii^^Xh^^^y FSft5„ d77^ 
(4, ffi^s, Hill-S* y ytfy^- V-^vft Ucfflg* 

iifflBl^T-fo-58ff--fe-y F£ ftS. &#<oHI!g«>«5teliI 
{£ u^i/b* fc (4 l~</u • r K f*(4, #r LV^iS 1/ = - F* 
ro^)S-r 57^-A'Ka»6T^^-f^aiV'='-K4 l 8 
ff)W</> (A DDR) 7-f— A- K (Level (Addr)) (C => 
f-£ft5„ ^m^=— K4 1 8<Dm&7 

?/DDX7 ^-/V K (Seg.Addr(DDX)) {4, $t#y* 

tB^JCtt-fe > V F » D D X <|>ib = tf- £ ft£ ^«<^ 

-^ft^W-f^r (-fftfr*,, DDX7-f-A-K«M 
-rsftijS) ffl^-KroWB«£fcft5. 
[0 0 7 0] il2Ai>b, ftfiW^-^^itt^RgT-fe 

#7- Ku^iVDDX?^ -A-F'f4, Sft57^-^ 

[0071] Hi 2Bii, iflftS^^^-zM o or-fc 

ffl£ft.&, ±-ettMUfc#* LV jHf=»-K 
tf>I2B£^-f 0-t?fc5„ iZ2:/-A-4 l 2t4, ffT^r-f 
^ja^="-K4 2 8, gt.r^-r-i'T'ffl f*4 3o*j 

.tU^tf/l" T^^-f P r i3U'='— F*4 3 21C,toT:ffiS 
&ft5„ El 2-B*>6*>*>6 *5t, K4 0 2, 

404, 406, 42 0*54. T>'4 2 2(4, fo5B#^,T'W 

y^y v^ftaiaro&fcjsii-c, -y-^x^ib^ic^M 

tSI^ftS. &U-=>- KI-14, ^fffly 7>h402 
<Di§3-(Cf4L O AD E D G E S A ND RENDE 

R^loSS^&tftfcs r z Efic^tSiSSW, 
HfMt^-g'SftS. "(04 5 ft^(cta^ofcB#^l4, 
SIZEfctfcSU 0-Cfti/^*g-^l4, SfL^iau^- 
K©7K^4:P-h'U D * F 4 0 2 X* 
ftJfci-SRfffcMUM"*. 
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[0 0 7 2 ] *f*L^3IJfe^T'l4, iava-KroteS 

rofcfc tea t =t tuz MJi -r 5 #<< > 9 & ^ffl-r 5 # , 
fci^ify • y* hftif«, 

r y7h7x7 • ^- fc (4 t 
1-5 a* -e* a. 

[0 0 7 3 ] 0 8K*£ftfcMfe7 8(DA^jftU>^ 
y^^^, 01 0IC7j*i ft + ■ 7-03 4, 3 

5*5403 6^B5iiLtr.^&IftW-r5 0 
10 (4, • 7-r^cOfTL.^xm^roH-S^- Ift 

IKfrW&fc-rSfcfcl^ll&Sft, 01 2Cft.^L01 2 

8, 4 3 0 *5404 3 2CD 1 -O^b^ttl £ ftS. 
[0 0 7 4 ] 01 2C(4, ^^ft>'7^y34 (*M 

Wro#^H^Jg8 o<o%±ffl (Di-y^'J yynmx- 
<7), ±T'3ifi-«fcy x FcO^^*^-r0T-fo5o 

■ 7^^3 4fdf4, «fLv>iaasft<, Lfc^oT, y^. 

h4 0 2iO^-c*fc?>ri:(-@s$Ktl'\ ±ffly^h4 
0 4*$J:O t *3Ejay ^ h4 2 Oro^Wtli, 22 8 2 
20 3o±U<8 4 1*tt&$£tlZ. y X b<D-t^^*tl^(4, *f 
f£:i-5*-< 4 3 4, 4 3 643404 4 0^*tl, 

mfci4, > ■ 7<< 4 iTJ^TSft-, ^f£?-f5 

fS-fay x h<7>*JSfc»tfc»|;:&£ft, 
(*) (Cior^^tLaiE^^ V^4 5 ofc^-*n 

5„ y • y * h£teffl-f 64B£t-t4, y^^-y^ 

fr*H5»t?, r»4 7ftPH#'K'f V^I4>Fg(Cft5 0 
[0075] i-e^fci 51^, ^*t7 • 7^>-» 

30 ik±mvA F4 2 oiiffly^ f 4 0 4As« 

frLv^ffl^, frffly ^ F4 0 Z\c%i»fyhh%* 

mwj* F(4^y/$tv, ^v^w^Jxmtt, # 

y* Fcog?oeo^y^4-ffli-J:5tc-irs/ F Six6„ ^^r 
■ 7^ X3 5 0fe*-C'l4, SEW401 2D»±5l: 
ft5„ 01 2D*»bW»5 4?(C, 1/3- KKtt, 01 
0^^)29 2, 9 4, 8 4 fc4t/8 2 \Z*tl&1rZ>Z. k.ft 

bM4ow7?7--f7ii;ia^*ti5. 

[0 0 7 6 ] 01 2Et#B8i-5t, 
*fe$4x5NFK, Sfiau-3- F'4 0 2»ftSiroS»!JS, T 
40 ^x^7'fflU3-F'4 2 8|CP-K$n, ±ffly^F4 
0 4*540 ? ^f^ffly ^ F 4 0 6<7?ftS)C0 7^x-f ^ft 
iai/3-F**S, tn?ih-l/3-K4 3 0*5J:tJ ! 4 3 2t 
3^-4*1,5, "Wt?i|t?l4, Xf/ioSy ^ F 4 0 6(4S 
tffo?), LtaSoT, p— r-f >^l4fT*?ixftV\ U<=> 
-F4 2 8 , 4 3 0*340 4 3 2 rtrofflW XffcB^JtK 

$^6o :ot^, ^T$ix5ffl(4, i2 9 2lC*ffS+5 
i2T'fo9, iroffl*5^(D^5fe)ififfitii*(iai7lSn5 0 
•fWi, /ft-f >^4 3 4, 4 3 6*5404 3 8 y* 
50 F^«ftC0U3-K^jSi-4?lcHff$^5 o 
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[0 0 7 7] iaSESS!»S3SffS*ifiiZ2^K*r*tL 

T2T*T ":»MTii 3 oiofi^Mf?' 
f^Xl:45. 38fT$ftfciaa s 3iftfcy* h 
tttl)^M02) rtro&OJgBdS, mi-^i^^-K 

(r.co*-g-T-(iU-="— K4 2 8) lin-K$H5„ dft 
£EI 1 2 FtSt. 

10 0 7 8] $P>tC, Ell 2 F^Pj^ej^iiSS*?. u 
v'x?4 2 8 1 4 3 0*54lM 3 2 (OffflrojfcgSldi o 

&roia£ft (X=8 5, P= 2) £ LXliitl £ft5. -t 

7-^4 1 2 fcilflPSft. ig 3 fttf-l' Tri^ 
y? y > >- h £ft£„ E#r£ft3ffi(4, x<- 

X + DXlCioX^X.P,^ ^r-Cll, 8 4 =8 5-1 
bLX Sfc, ■ *»b*>li»6J:5E, IU' 

ja«sK'f>'^ 4 3 4!6s, rcQi§#T'ii#fiay * 1-40 2 

[0 0 7 9] EJ12G-CI4, ft/hcoatTXM 4:^1-5 i: 

Sft, ass (x=i 1 5, p = 2) iutbAJft 
5„ *lt, saws*?**** u 0^4? 

i Jsa27 P -^4 1 2(IiiiP$tv5<, C:tf?B#, ffl7°-/W4 1 

2 ttWffic* 9 , ::*>6. */M>x 
WS^ ffi7j y* M 2 OicSgffSft, 
-fy^i!, *fttSfPW£»i£ft3o 
[0 0 8 01 Ell 2H7)>fc:fr7>3 4?l;:, ^coft/hOiS 

£ft5 (X= 16 0, P= 1 ) „ j m<9ja7 , -vL-4 1 2 
a*1Efr£ft, »C(c/J>$V>XfiE*Sffl^y^h4 2 0(-3Sff 

£ft5o 

[00 8.1] Xdf-r >- • ^3 5<Dif(|i5 I'-, 0 12 1 

*>ib*3*»*j; xigco/hs^if-e, lar-AM 1 2 

ro^/JSffl^J y ;* h 4 2 0(C 7 7 ft 5. Hi 2 

j j5»e>*>a»s £ 5 fc, &±>a y^h420i:iiay^h 
4 0 4(4, $.<nx*-v> • y^ysGcou-syy 

£&«&(-, Ell 2 j*>fj*?*>5J:5(c, ±53 y* 1-4 

'■f-^-CjJS-tS.ft, ^ftib(4Xf£gW>iT-SaE§tt, Cft 

laot, Siicou->-yy ^^^^^ic-rsOEfi^T^ 

-fe^^Blne(c^S a 

[0 0 8 2] a». SrLi^ffltt, xffi|iro|HB-x?ia*!Hl 
*i> a -vu4 0 0lr±o-CSCt®e>ft5. *rL^ia*sa 

ftS^df + y • 7-r>-cofcft(iH-^$ft) . :W:io 
X, &Tro«ig;&sifc3S£ft5. 
[0 0 8 31 (a) JE*fSnfcttH*««*»4 9 8 (Cffl 
$ ft fcft tt o) Xffig 4 0 /Jn $ v (c i± , ft L ir'SB 



14, ±* f • y/F4 0 6^By-F^ ftSjf AT-fc 
9, *tJ£;-r51SIH'^^*S!e»r*ft5„ 
[008 4] (b) ^?-Ctt^i§£-|C, gRflasfesftC, 

.... jI( ^ maia . 7 .. /P 4 r 2TS-~-Ctt-*Fi* ft 5, 

[0 0 8 5 ] HflME^^P^e^t*? 1 ?, iB7'-/U4 1 2 
(4, 7*?{b»&«&ro**-v:/ • ^vcoi^yy y 
^fcffi*fc»Il?f+£rojrc?roy * hroSSrfcftjttS. £ 
<bic, ffl7*-/U4 1 Zflt-/ %>&.<Dm*ttttbft 
TWj^iaEii^SfcftK&SE-f 5- t *ST-^6o L 

io a>L, ^(-(4, a7"-/M l 2tfs, -fii:^7 7-f y 

#1-3, mmmMft&ifrz-bitw&x'foz. mm 

W*E*-ei4, ia7°-/u4 1 2^fHt5rii:t^5 
as, rftll, 5i#(4, BtfSftfcfflSr, &ltitim<)xh 

4 2 0--W y- s^ftfcif AKi-a^fcfcj&ait+s. 
l*>u »*Lv>HJSfl?ffi-c?(4, ±-ca*-«fc^tr^- y 

®£ft5 0 *tf/u- y* hfcKttaetlcioT, 

ffl^-zwi^f^- y^h* J 3as;awffliit$(cjg^i-5 

W(c7F+^.(C^5*-g-C{4, ::fttt#fc»£'T?ifc5as, 

y-hisfe&ffiffli-SitasT-ts. 

[oo86] * • y ^ h #Nsias{£ffl s ft sis^ww 

4, Hl4A(C*1-„ Ell 4A"C(4, 3o<73ffi^«j23 6 
0, 6 1*54^6 3*5, ^^•ry-7'fyAfcJ:O t B» 
^wt§W4Sfftt«ffl6 2 
•rx • 7-1" yAteit^Bro-tft-t'fttov^T^ta^ 
30 3ft5HffM2:g-6 4ds, x/-?>U^{igc>j:^L J t L 

-CEl^SftTVS. ffl7°-/W4 1 2 a s 3 O <Di2 !✓ 3 •— K 
4«ff-r6f--<XT?fo6, ±T'|!iWLfcfi3lr-|4, rwi 
5*Sag7t*lt-t'(4, EH 4 A(c?P$ftfcP®i-5^^-ir 
x • 7^ y<r>ffl-e%±-tt> 3-3«iaco5sgi(c:ii-g-f sro 
(-^+7>-e 5 i k itw e -cfo s„ 

[0 0 8 7 ] El 1 4 BIC, ^df -yy • 71" X±Wia6 
0, 6 1*54^6 3«rl^y^y V^LfcaWfflUa-K 

ST'fo 1 ?, 527*— 4 1 2 (4, ^«7.dr+ V ■ 7 4 >X' 
40 fc6Xdr-r y • 7-f ^BKlfcftro, ^ft-?ftffl6 0, 6 
1*5^^6 3<7)JgffSftfcX(iSE, Gt540 ! I-eSSiWi 
4oT^S. ia62!4, 5T?f-f^ai'3-K4 3 0 
(CP-K^ft, 27°-^ 4 l2tmfc%<VX-, 526 Ofc 

*rjsi-s«/i»wx«*«, rn^ffly x b4 2 oicitiTj^ft 

[0 0 8 8 ] El 1 4CT-(4, i!fcC0ia5JgaS^tfSft (ia 
62«X=J) , #j6i-6 35«f*ftfc«t, ^ro»#(4^ 
jf^y • 5^ vB»x = cas^$ft5, ^fci^Hff^ 

fttftX=C(4, ytlTJ y ^ h4 2 0!J»b=»t?-£ftfc& 
50 tftjfi(75fflX = E4"9/J^V^-e, mffi^iai': 3 - Kt 
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[0 0 8 9] 014DC, • 7^^B<Dm^ 

roi2u=*-Kro$f§£^l% ^coar-tt, ±u^h*j± 

ffl 6 0&mT?T47"Jl^V7-'? 4 3 0C 
P-KL, 262^, *¥>V • T?7-4-?m V-i>Xf>4 

3 2lcc-Kt5„ xfiffrisjfcRSix, gyhroxfic (x= 
C) «r*+5ia6 2i»s*tf4*i, WrSft, 

l 

[0 0 9 0] fflroSHTtJESftt, iiay * h 4 o 4(*iro 

(C, 217*-/!/ 4 1 2^7 7->->^$tir < H14EK* 
$nfc^5K^/^5 0 IHEi'btt, i26 0 #l^L6 3 

[0 0 9 1 ] ±gE^&^b7Wd&54 ?(d, *fc!>- y 

NSff©^*fcfct>+„ is biz, Z<D))x h#1NfXlc 
*vc»«K:iE3Eiir*T*6rfctJ:or, i2£groSfe 

-r^-troiasn-ey- h*if fcHs&ifjfcLeMrc* 

5. 

[0 0 9 2] ^U^JStBIIBT^, i27°-A-4 1 2 
(4, 8oM I/a- KSrtSff-fSIM Xtc^ti, y*h 

4 0 4:}34t>*4 2 0roiMX(4, -tnfstcBiai-S^f 

/w^mo 6*j<t^4 2 2 t-mz. mmc^«j 

mx-hV, r fit* of, SafcMXSWtfctftS* 
[0 0 9 3] «JHKttftS*J>a-A'5 0 0 
o*»6ro#ffi^ f*~J?4 9 814, ffjfeWffiT'-^RS 

-fe-S*fc.fcOU*+V- 7-f yro*!M j/-fe-i>#£* 

J:o-cWWftfe*i3l»fc, SfJfeAtb^ffiL (F I F 
O) /<y77 5 1 8£iijg+-5 0 F I F0 5 1 8 f4, 53 

a. - ^ 4 o o route t fi&ftnifefcjg * v? ^ 

5 0 0roiM»Mt5J:'9i:i<. flEftMBtsmffir-- 
7/1/5 0 214, ±-Ci&'<fcT-7/l'3 4<n-$f,Z-$t! 

ronffiffl$tu5o F I F0 5 1811 lyi^Sgro** 
+ v • y^^ftroaflig^v^-A^ o o^brog® 

(9 £ffi$fc«Sffi:iK1&7 1 -7'A'5 0 2-.ro$5i^«r^-ro«!.g 

r, ffiJfcJl&ifcsS*^ 3.-^ 5 o oas, iwj- rowiff 
(X) ffi*Tro**roffl3SS6*:»4*WK«M|-e#SJ:5 
(d&s„ ffi^NSffi^(ST-7' A-5 0 2ro«-u-=— Kid 
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[0094] ( i ) r. roffi &mm\ l 

mi1z1ta#i£ v ■ 7^vx-r>^»L&fUJroigffl(c: 
i-^L^Sij7y^ 

(i i) r\ro«*Wtt4rt>fcb-r>ai«*!Si-afctrt» 
it L^liJId J; o T /^ * ®T-^M $ *i3 §£» ? V 

K 

(i i i) z<nm&mtiLifi* V vt?>?'bmmL<nb'h 
io f,(^ffl*4x5i6»4:*-f^ y y^- 77^ 

(i v) * y 7?my hsjvcuaafcov* 

■ *-f 7°- 77^ 

(v) rroSMfKttf.t^'/T-'/fy^/fT- 
ro?y yT^KASBfKT^y^y ffi5s#(c 
-fy^D^yl-Sji, rro«5fe«S&Srtfc?>-t-^ y y7" 

■ rtb ■ ^^7*ro^y y^mm-A^^y^D? 1 

20 

(vi) ^-F-t'pJj 77^i»t5 1 :ro|St 
HffcdS*ix*}Sroi/^SrgSltthg:-t5 zk&&&b 

[00 9 5 ] fy^ • ah/v^* h (4, 

^T?|!E*Pt?fc*Js W£rotfU^7*i>:c 
4 5tcft< roT(4ft<, iHfertroS'Jroal-T'^x* hro® 
6 Hy^-t^xn 

U Tiryic-tzzbbX'Z S„ fc |2I8ro^-7^ 
30 S8 0 [4, ^7*^** H9 OtC^LT, ^7"^ ? 

l- 9 oi7)7 *>x^ y y t'y ^ • *7*s?»* h 8 o roTic 
fo 5 fifefe-T^ J: 5 ir ft < ? y 5/ t°y f • 

^Ifrt(ci*5lt5s st-7*^*^ h 9 oroTl-fe?.. ^y 
yySix-CV^im«5i-^*^ h9 0 ro5Fig$ £ 

[00 9 6 ] ill 1 3 A*5 J; t/® 1 3 B S^C— (BfcM 

40 n • x;/ffi[HiJroi«jrofcjf)(c, 013A^, 

ifJ'S^V F70Oi27l j3J;t/7 2^, Ja^TfS]* i: 
-h[6) # ro if t, e> -efc 5 !*o -c«fct:±ro [Si t t'ro J; 

jaw, ^tdf&oTi&jfet^^sfi/is^fy 

rofcfttiafc^.^f,^5|6l#»4, ^7>7)^ft$ix5|ii^: 

[0 0 9 7 ] E l 3 Btc, 2oroTl6]^roffl7 3*3j;rj! 
50 7 6 t, 3 oro±|^l^roj7J 7 4. 7 5*5^0*7 7 %%1r 
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^■Z-M&Z^-mz- h^A-L, L^oT, 

ot^tfcf&c-c^mL.*^^ brnz^y? y 

lif^ y * > M"5. Ill l 3 BTIi, rro* =>f-\r> • 7 
1 , >-C(±5^5ftl9]W2oroffl 7 3io4U<7 6#T|6l£-e 

7 4*54 7 7(4, ±(S]^T'&I9, LfJiot, ttfltL 

[0 0 9 8] ^<^fr<o%Mwmx'\t, z<n\m<o-% 

* HcoffldMiiU ffl£St> yfe— -705— SE <k L"tM5fc 
0 0t'^ai$H5 o ftftftjl-s? 

7" • 77^*5<J:U t =- K ■ • 77^*, r.<D 

[0 0 9 9] EI5teMoT, **l«fcJE*r*i>»-*5 

0 6li, ^^^^a^^TLfcicos-cw^^f-vy • 7 

*t*r. '«ft»itt3E*f*^a-/i'5 o 6 vmnxtfo-r 

[0 10 0] F I F05 1 8 <7)$fcsB-CgttSX^fci2£ii 

o 6(4, yt-wx&mmtzomrx&it 

t^-/W5 0 6<ogtfTXE*Tro$£-fcl4, ®5fcJp{£35 
^-7^-^5 0 6(4, ^Wia^^yt-^J&lt 

ias^^ •>-fe-^w«ta(4, 2ow^(c*o, 
rii^i22*aaj (TtiftW-f-s) (4, mx&tr*-'. v 

;V5 0 2rt» U = - K/J5. ? y yf&.Wm.X'ti.^Z.k 

*v>»#»cB, r*y yT-ia&gj (T-eBWi-a) *« 

[0 10 1] ffiJfe^^fcSllSS-CT^r-f 7 r (C^5co 
(4, *wiiiS§as, JtroftjfelifiroamuSaiJtaoXffi 

<n? y y7*- hatoro*ft-e*>5. flEft«Bffi(4, 
*ft#ftt,±<07*^77B«^ffi-ck.&»£, *fc 

(4, -t;ft4 9±ffi:c9T?7V 74«Jfel(Sffiwt'«tii, 

fc, amSftfi. ico^t?, mit, &M3Jxfc*ite 
HffiroMt Lt-^ fc'tt ffl L T^fiJct 5 Z t Ifi X2 

[0102] *>5«ftlHffi<o=-K • 'fc?p* ■ 77^ 



i4, a^y ^ hcoiff^rtT-^sc^n, W7ymy 
h $ Jxr ^ t£ (tti(4, OH roflEftnna: cot <r>r vf-i? 

5o r»77^(4, *H*W*B*«c±<**L*^tt 

•r &k <• <o \cm a k. & y t $ n 

3„ 

[0103] ra^ffl^aj i~(4, sasn^ yt~7rt 

[0 104] ( i ) ^<75®5feMS{4»SftroS«tL*^ 
>-h&IE^L, (i i) mft«<gJfe||IfewaiSL^aiJ 
545, ( a ) SSteKtt. iHW^h 

0 » ^T-foh-14'^m ^ V 0 y h L, 
■t ?f*V^»^^i40^(7)ffl[«r-fey h L, (b) ftV 
p • C^f >7-f >y-Cfca*-&(-(4, 1SL*^F* 

-r y t ybitMf^ y h mnljfayjyv. 
jJJCT) L, (i i i) jKU'Mtl*»:"H&HM 
20 ^fc^«L*^y h^JtgfL, -*?JS0t?flfe*i6S0^ 

[0105] VKo7l^^Jg^fl|X'(4, ffl^^p< y-fe- 
WBffi w t (c g'J * Wia£g> y -fe- i'SrfiSffl 1"5 C t ifiX 
[0106] T^t-^7- 77^Hfrii^l-(4, *r» 
r^7^7' • 79^(4, ®$te»S{£ 

30 ^7-7-^5 0 2©*W«jfelHtt«)»«L*S?l'h# 
OJEWCfei?, ^roftStHtfco^ y j/7- *\7^h^0 

B«^tOWt/£>), 9T'/iV^-g-(C:(4, Ti'T'C 

7" • 7 7 ^140 Kites, Ti'-r-f 7- 77 ^StrKi^ro 
|2^7'/7"li 1 Ti^T^-f- 7 7^ia?'J5 0 8rt»^l 

Sg7-7/uro=- K ■ Cb i? • 77M ! o ro*-t(c(4, 
^ig^T ^ r -< 7* • 7 7 ^E^iJ 5 1 0 ©affi©M5fem{4 

« Z~bX'foZ>„ 

[0107] y y^ffliaaj (-14, y-fe- 

7/U. u=,- KW7-f-^ KCSLT, HTWfyT" 

[oio8] ( i) 9&<o99cm&.<om&<ovm 
v h &ie^ l, ( i i ) a&w«jfeWttroa»LjftHii 

(a) *HR-«fcT?*> 6»#fctt. ^ffL^^^H 
#Sfe0 a^tAixtf IS W M: 0 4t y h L, 
*5-e4^«*Ktt0^fl3«*r*s'iL. .(b) 
50 p.p^yf^msiHKIi. MftLTJ^yh^ 
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jfc&r) U (i i i) ffL^^ff L*<>> h*E»<* 

o, (b) $Lt£<nmfflm<L<» * y ^- ^^r- 77^ 
as*? y r*i»-e*>t>, Ei^fciHL*^!- 

iSOT'fcl frL^gftL;* >vh^0J^r-ife£» 

ni±, +1. (c) *ft«rt«>»*tEr*, - lo^ y y 

^•^A^KfcftJEU (i v) ia5£^> s"fe-J?«o* 
rtw^-Kfl^ y y7"- * ^H:»£Slifc# y y 

7 ? 7^ 4 7" ' ■yyyg.ttwiftzmni-z, 

b<b®®m&> tfHCtfc^LfcLOAD^LEVE 
L_PROP ERTI ES^J^-JCtor-fes' hSJtSw 

fcdBfcSftfcK * y 77* • nvv bit, sum, # 

[0 10 9] ^<o^«DHJfSJgffi-Ctt, ffi3te»K#:riS? y 

^r4A.6H5-r^r«ffi5t>ni<73^ y y7° • 
^ff^t^^y/^Sfcii^y.^hiSti-s, r 30 

coKiifcW:, fc.fcx.li, J'h/IPWfc?, ffiiff 
*^tS Liffll wiiffl fl^gft H#(cffiffll-£ r. fc &X $ 
■5, rw^rofSffl^rtt, iafcj;orffiijffli*H5W'< 
y yT'-A^nt ±iPit»a»4§^-i-'C -/9 
y*>h$h> TftZvmcDm&izT?* y ^ ^b$ti 

[Olio] a*** yfe-v?©x^tt!is, ttftffitt: 
fcJE*r*5** -^5 0 614, 4fig-f-5H*'Stw*9Vh 

7*-v>m g^5 2 0 &^Lr^5 l cH&^fK ; e^ 
a -/i>5 1 6£i£6. *roft ; ajfeWffiMr*^*-^ 
5 0 6lt iT-^rofiicwH^ w&Sa^T Lfc^i Sr* 
-rffi^Hi^^^^^-^s 1 6rf»e>ro(g-f§-5 2 2 Sr# 
o„ ffi^-5 2 2^§(t®-pfcB#lc, «5fejatt3E*r*i?> 
-A-5 0 614, tmSlffXt; i22^H^ yir-v^XS 
UliSr-fe yH, ±T?»9! t fc^SfcSiiiif -f S„ so 
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[0111] ■5fc»HM-J**i>»-A'5 l 6(4. f~7 
a- 3 4rtr fcjgfigs^s, #ffi5feiHfi;tM-f5tt^*<* 
JH-aroKftfflSftS, <I Miter-* • r-7*^5 0 
4tMLr»f^1-*. ffi^HHtex-t? • 7;-7>-5 0 4 

[0112] (i) MLf-^-rh'^ 
(i i) 

(i i i) 7**«g=<- K 

( i v) 7/>7r • r + ^^fHg=i- K 

(v) ry-x • *rf\ V7>f 

(vi) r^r^-^^'^j 77^ 

(v i i) r x ®ftj 7y:/fcfrt5, :» 

ffijfell&rofe^m^roYicJtLr-^rfo&^^^^Sr 

[0113] fffcMMficayS* yt-^§«() 5 2 0« 
ESC:, flE^«gf£^fK*i 7 3.-/P5 1 6(4. 8«&£ixfc7j 

ffo (TrtftP^1-5) **frU twgH-CC:, »fP* 
£7Lfc::fcS:*qfc*$fl , r-IS-5 2 2*r«5feWffiJE*f*^ 

[0114] ^-W^ro^Jfe^^Dj^ttt, *-r*a 
I^T ? T 4 -f • 7 7 5 1 0 \Zft LX SftmOLx- V 

(fciitf, 40 9 6jSflZfyh«5feW 

1 6 i»>e>tKfllUS^clH&> yfc-m*j5 9 8Kl»dlS 
(d, ^liHa^fjcoxry^tcior^S^Tt (rtt 

**t*ii»o fc^(c[± N mtT®5fe«R&tco Sr-fey h-f 
5„ tro*, *5fe)Rttftdt*^-/U5 1 6 14, 7?f 
4-7° • 7y ?wm5 0 8 tr^JS^r^®5fe>P{£^^ 

6t/h»7?f^7-77^ftSt5. *<0J;5(^ 

0 4»-< vx^-y^/lcffifflSH, -troi^K 

5 9 8, »!T«ft)ffiffi 
S*wi<ft* (■*-«*»*>, afT«5l£Wtt«:«i6. 

r^7- 7 7^-e77/Sr4re>nfcffi5fe'«{a:* $ *<' , i 
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[0 115] ±t?KWLfcS**ifPC*H-5»*LV^# 

tiLt. 1611, 

A-6 0 0(dg^1-5^^ y-k-v^x»[47 7^roffi£ 
(4, Sffi^ yfe-fSr^O , {r 0>&© 

ffl.atD-r^-cwf-t^^i-^SLfe^^^^^-^e o o i 
fcj£$ C i (c J; o X'frfrtiZ . 

0*U«iU, «ftW(t4dt*5i ! »-A/5 1 6 
14, «-W</u&j£> 5»*-i>W«fc:, jgg£5 2 2&J>L 
■C«56l»SaE*f*y»-A'B 0 6fcjMS0>*SW«ifclli 
ft£i£5„ 0 6(4, rtiSrX 

hT5 2 6fc««i-a. -tea, «ft«ffiIff*-^»- 
0 6B, > s/-b-i*0X=fcJfei«BfTX <fc 

< ifclois, &iii©'FSWffi5te«Bte«±-efo5wtS: 

[0117] v><o^wj|gr-0fSl$4x5J; »^ 

^<o«i8*, m^mft±^^^-^5 1 

Ct^^LTitfST'tSo -*U4, fctx.l4 4-fe/U- # 

Six5i:IBl^(^l6Sri(8iB6-e*, r^iKio T, (±1775 
9 yVa©77S'f ^.t«4l4lc!!fewflEft«S{fe 

§ J: 5 Kft So 

[0118] 1218 & it/El 9 A, B(C**ftt^77^ 

ma:H*f*aa*r, eii 2cftv^uai 2 j&itfiai 5 

Att^LWl 5 E(C^$ft;ti2«£3t£fi&ffl ur, 

■r 7-f>3 5ic||LT^-tii*s-e#5. 

[0 119] 01 5Aft^LBl 5E(i, ffiifeNBfiv 1 - 
7*/U5 0 2*3j;O«5 0 4ro»)^*S5i-gl-efo9, «ft«S 
ffi-r-7"^5 0 2*Jj;t>'5 0 4(4, £f£U^HWfiST' 
(4, S2?U5 0 8*5itf 5 1 0 iiy3-^5 1 2*3<tO< 
5 14i#IC, U^lx- x-f 7''fK'7 1 -7'^5 3 Oi 
St5«-«r-7'/H^iSn5. Hi 5 Afrbfrfr 

OA^^^Y v ■ 7'C>-rofI-eS(tSi?5tL, r- 7*^5 
3 0(cn- KSft. 7^-7/1- 5 3 0(4, ffiSteMSfflWd-C 



[0120] [2^(73 U"</U ■ T^-r <7'*fb7 i -7>5 3 
0!C(4, #-t?P • VAS? 4 >^MiiJSfc(4, ilSftit 

77^(4, S5fe«SteW#t4T-fol?, LOAD_PRIO 
RITIES_PROPERTI ES^^fW-gHt Lt 
-fey S 5*1-5. =-K- fn!7(4, t-7>5 3 0#p 
- K£*i5i#lc:. r^T<o(IMi{£i-"<A"l;io^-t-fe-> 

ssti-5,, y yT" • * M fc-fctf rj&jtu-i'i' 
5. wi/^fcr^T^^ii^, *ffS-r5*i 

tO«Sty S*nS„ 5£>fc:, S3?iJ5 1 0*5 J: 1*5 0 8 

[0121] 115AH, «r±. 1S»WU=i-K^ 
9?^S»fcfe(^B§$^T^5ri:l4l«eT-fo5„ 3 

i"** ■ T^r<7{br-7>5 3 0 (c(4. 0Etg>P 
&©«B-eieg$Hfc, WTWU=.-K^^*tv5(4-f-e 
fc5 0 

[o 122] -asu^yh 

• ? y ^7° • h 

• TE££ t?T ? tV 7<ffc *fr*5 5 ^ 

i) s- K- t'p-7 • 77^ 

ii) ?!)?7"- ?-<7" 
i i i) 

I ?* = K 
i) TA-77 • f- + */HMI=i-H 
i i) ry-^ • TKy 7* J 77^ 
v) rf^f^-ygy^y/j 75^ 

) X»477/ 

^*L7-7*/W- ^yfy^. 
[0123] X-7/U5 3 0»rt§(4, ffiitlitei*;^ 

-7^.-/u-5 oo-e^fflsnftv^iw, iSS4^ffl»s 

^Lfe^S-=&v ; = -/i'6 0 0 t-g-^StStfflWli*^-^ 
5„ 

[0124] /*iy-7-fy3 5COft^«fflS^ (H 
1 2E) «rll SAIC^i-iS, 0 1 5AT-(4, P = 1 «W 
tl#(c, ^SflAfyMi, *H?n • yr<y« 

ffiLftV^-C, r=-K- fo!?j (4, 0 tc-tr-y 



[0125] ?—7iV 5 3 0 (Ogjcoftjift-fe y h& tlX 
W.ev 6e?'l5 l o&XXfiS o 8 ft, -fe y h £*tfc 
9 . ***{fc*v = -^5 14B, ftftJUtt 
(7)m*Srr-< x^-7>£*x5,, ClfUi, ffi5fc«ift:£fifc 
*i?3.-/i-5 l 6(;i,fcoTfi¥??£;h<, ffi tg»II v 5 
a-/U5 1 6 I*, • 74 'S3 5<r>%L$](DQ&<» 

gp^T'foS \*1*J*9 hfcu ffiftHIft (fciitfP 
= 0) »*i?yFn = 4o (■*) zmtn-z* 

[0 12 6] 01 5Btt, H 1 2F«ffi£li£&§ftI&o 

5. ffi?iJ5 1 0*3<fct>*5 0 8(1, 

O^feCOffJOT^Su^^fflVMT-fe^ hJtiS. -con* 
£-C\ 3.-^5 i eft, ^mmn^-fiMa Ok<D$i 

-r, *^u = 45, p= i fcm^-f 3„ 

[0 12 7] |15 Cii, HI i 2Groa£H£g(7©o 
t!S>5^i? Mi, TS^tiiftv^-e, 

iftifi:iV3-^5 12^, n = (115-8 5) = 

LT®7clff£P = 2&^1-SraKteffl£*L3. 
[0 12 8] 01 5Dlt H 1 2HCDi2&H£gft®o 
fcB#c0Eg£*-fl2-? B«ic5E55$fifcP=2co 

*l, Lfc^oT, tomm* n = (16 0 

-115) = 4 5»*«sfi : -c-fo2)iip= i *m*i-5 

[0129] 0 1 5 E ft, 0121 WfflSS £^(7® o 
fcB#09*g**^1-|2n?*)t), n= (180-16 0) = 

2 0Hfg«P = 0«ffi;WW££*"tSo 
[0130] Lfc^oT, ffjte«tt*^a-^6 00 

ft, *=*r-r> • 7-f yoo-r^-teopi^ncBa-rs, 

[oi3i] ttaLfeftS^^-^eooroftf^*, 
ge^iLT, »TKi»W1:S. tfftWffcW**^* 
-a- 5 0 Ort^bro^B;* y-fe-v?5 9 8 ft, ^iftr- 
?®fc3£*y-fe--* fit****-* M*L«ftJ«tt.> < 
y-fc— ^, IMO^yt-^i^^ + v-?^ 

fcioW^s^-^e o 4 fcis^ns. sttLA/y? 

r y y^O'SW^i^-A- 6 0 4ft, &ift Lfe^S^e 

[0 13 2] ^dr-Y > • 71' 'y(T>m v ) / yfe-^tStt 
/1/6 0 4 ft, 5Lfr XffiB* !> 6 1 4 tr 0 C y -b y h 

u sfrY&gay-xy- 6i 6«r-<y^ y ^ > N-r?> 0 



(24) #12 0 0 0 - 1 4 9 0 3 5 
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*dr-vv- 7-r><o^t)^ y-f?-v*ft. M^S 
rit*i#3L-/u7 0 0(>ijS$n6 o 
[0133] ®SL7 f --*SSj£p t yfc-^&Sft&ofc 
9f K ft, ^ LA y ? T y 7"*5 J; tfftiffl* i? =. -A- 6 0 
4ft, IS Lr~? ■ 7— 7* A- 3 6<75ffi!ti5nfcftg6 

0 2(c-frK>7 ; -^*iBmt-5 0 
[0 13 4] y-fe-^fcgft&ofclftfcitt, 

LA-y*r yytjjivsijsi^^^-^e o 4 ft, fcm/ 
y-k—yfrboXfy heftSfTXffig* (7^* 6 1 4 
10 Sr-f V9 y ^ V h-f 5„ y-fe-v»ft, H 

^-&)t*^^-^7 0 01c: 5. 
[0135] yfc-UfrJfcttttofcWfc 
ft, ?7 y ^ -^6 0 4 

ft, ^ftoaffx{4B*^y^6 i 4&-f yy- y^o-s 
U rroHSroiM ^ yt-v^tt, K^i*^ 

0 0f;:Jg£*"l5„ 
[0136] H»Lffift»ift;< yfe-i?*rait»ofcl* 

tft, iSu^r^fiWISt^^-^e o 4 
ft, TBroasfeStrftflsfcSHT-*-*. 
20 foi37] ( i ) MLffftMft;< y±—yfrb<nm 

[0138] (i i) mrnvrnftmon* yt-^>b«) 
[0139] ( i i i ) mmLiMftmiiL/ y-fe-^e. 

f-7**v : ; x-/i'^^:^L, iiWi-5 D t7' ; t-/^-/W; 
30 ft, 7^^m^:y^— ^6 0 6, 77'; h • • 

^-^6 0 8, y-r • 7^'*7-'^- 
^6 l 0j3±Wi8W^'f* ,; t^-/V6 1 2$r^fc 

[0 140] ( i v) ftS^iltl^^-rKSr, iiftSiX 
fc-y-7' ; Ev :; ^"/l'6 0 64^16 1 2lcW*&-t-5„ 

10 14 1] (viiRJnttT't^-^eoe* 
[oi42] (v i) »ssixfcfei:^aw«tt, a* 

3¥=j-K, 7*77 ■ f-r^MSSf 3 - K, ■ n< 

y7°- 77 ^'i^f^->3 > • tfy7"- 79 
a-*7 0 0(Ci£?>H3„ 

[ 0 1 4 3 ] »* U*tt«Mrctt. ftfiSntfif:^ 
0040?flT-foi9, a^d^T'3 2 My Y/Wkft^x. b 
50 WRbtm-tZA^m^ {&<o&&<o&*n<n&&m(D? 



(25) 
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m> s gi3£V7Fmwm<nm$$:. Tomwx'&m-t-z 
t>K zntawte, fo<D®<£-^ bmmirzz t &x'% 

[0 144] 7^^1^^3.-/1/6 06, 77yh- 

#7— • ^v^-^e o 8, y =r • • #7— • 

[0145] 77 y h ■ 7J7~ • €^a-/l-6 0 8 li; 

^^U^ro/SfttlWJER^ftS) i:lo»8t'y 

£>7fe£#3^£ici*U 2 5 5l4^(iSt>tL51-**5 
^±£^5^ SASH'S) fc^trSDS:?* — ^y hco 

{ 2 5 5 

c l amp (x) = < "- X J 
( 0 

[0 15 0] ftt^8t'l±. D=T • 7V7 P • #7- • 

BSIRcx, c y*}J:0 t d£:3rtf@!£7*— -^y hcou 
B*ro*.rtt, WMLT, 3 ocos£» £Jg?TX;*r 

[0 15 1] 

r = c 1 amp (c xX X + c yXy + d) 
If clamptt, ±T££§£ftfc 

5„ 

[0 15 2] -troj; SfcfE ibnfc4ow^mi±, fet^ 

[0 15 3] fl*-roft*fe**3toro*«tt**«rffl1- 
[0 15 4] -^mm^Aiv- *V>=l-)VQ i 2{i, tH$& 

y h^mmmm, mm<Dx<m ( P x) , vats ( P 

y) , X**— (s x) , Y*-Jr-A- (s y) *<fct>' 
6 4 f y hro-vx^f&tfH^V*— -ry h<£>U=i— p 

tcW^-^IE^IC^S^S. t'y f- -^^^rt 
Wt'y h • 7" KU-*af±, *WS;r-*S$tL5o 
[0155] a=((x/2" + px)mod 8) + 
( (y/2" + p y) mo d 8) x 8 
[0 15 6] try h ■ ^^iS'rtcOT KU* r a j Wtfy 
h#tfc££4x5. &fi£*L5 fy M5lW»£fcM:. U 



[0146] y-r • 7V/' #7- • *i>3.-/v6 i 

4ffiro£$t c x , c yfcitf 
di:> y-T • 7X^»S$MST?J)5 2o«ftg 
llx b a s ejoitfy b a s e *gtfiS7i— ?y b- 

[0 14 7] 4fe»-tix^ntO^T, jgf^fltrfi* 
10 WMLt, glEBXYgiixba sejoit/y 
b a s ej£:mz3^<nm%I.£&Z>-&ip&ZZtlc£'3X 

[0148] r = c 1 a m p (cxX (X-xbas 

e) +c y X (Y-y b a s e) +d) 

m&c 1 amptt, 55croi9tS«$ix5. 

[0149] 
2 5 5Sx 
0 S x < 2 5 5 
x<0 

[0 15 7] 5^?M ; t^>-*6 0 6«, 
fcW=>— K£> 6o©aa, b, c, d, xbase 
XXUyb aset, D-^T*!) V^SftS 7**W£SIi 
KSt*-?! 6C0&7*? • 71" V^COtTs/ b&Om&fi 

$yb (b p i) t, ■»i'-f7'i:«rtrBS7*—»' 
xffi®.i-z 7j>fc7jH% 

[0 158] (i) 1 fy hfeHXm&Jft^SnPnft 
(i i) 1 t'y h©li^»>5FSWII*t«SWWIBi* 

( i i i ) 8 fy v%mm<o?\s4 ■ *<r-si>*%mm 
m 

( i v ) s t*y tmmm<Dm^mwxtr~*mm 

(v) 2 4v<yhmwm<o?pmm3&m,ftmm 

(vi) 3 2 t'y h»W*ro3fe*»tTaW«roW* 
m<D£<<D7*— 7y haSBT*B-C*)5. 

40 [o l 5 9 ] ^^HHIee 'yoL— A-6 0 6 (4, m^9^ 
-7- 4Wr- ^SrfefflLT, t'y MtMSropiSiM X 

(bpp) Sr»^1-§ 0 -tro®. ^^^H^iB^T"-^ 
1 6rto?fy h • T KU* a iite^^H-aL+S. 

[0160] a=bpp* L aX (x-xbase) + 
cX (y-ybase) J +bplX L bX (x-xb 
a s e) + d X (y-y b a s e) J , 

[0161] Iv3-K6 0 2?)>? ) roBS^^7'Kfo-C 

«!RSnfcB*tt. 7^^B^[1*7 ? -^ i ertrott* 
^fcTK^ r 3 j ^f>.®i9ta$^5, 
50 3o©8 1 OW8 h^lflSSM 



It. fctx.lf, 8 tr* h/M^ro^L'-i' • x*r-^m 

[oi6 2] ^ro^s. a*RrsB^^*^ 
*9^^if^x-^ii. >^ yi*xoift&ii*7 f -* i 6 

jS-f3«*KWe!>#ifcJ: Q %i^$)X'frZ>» 
[0 16 3] ±Bfc*rt-6ff*U^«»fcL-C,'ffit« 

[0 16 4] 

p = aX (x-xbase) +cX (y-ybase) 
q = b X (x-xbase) +dX (y-ybase) 

[0165] z ?7.9m l &mn*f-v 1 6^©4ii 

Sro^h'TK^a.,, a,,, a.-fcttfa,, &, 

l»=bppX L p J +b p l X L q J 
a., = a.. + b p p 
a.o =a..+ b p I 
an=a«"+bpl+bpp , 
[0 16 6] RIC, »MiOTIir*dHH<r«r, JJcSteft^ 

+ 5. 

r=interp (interp (get (a»»), g 
e t (a.,) , p) , i n t e r p (g e t (a,.) , 
get (a,,) , p) , q) 

ZZX\ « i n t e r ptt. &»<fc 5 KJgigSftS,, 
interp (a, b, c) =a+ (b-a) X ( c - 
L c J ) . 

[0167] ±©BAT?, SS4l J =f loor 

at) x-foo , fioo rssg-m, iBwag*«u»«fj 

[0 16 8] get»4, jJr-S-Wf y h ■ T K^t? 
«. 7^?ilSuIi§ifT-:? i e^ej-tJ-^yy ^^ttfc 

3:: 

[0 16 9] ±Et*t-f5flF*L^»»fcL-C, ££B 



(26) WM 2.0 0 0 -1 4 9'0 3 5 

50 

6 1 4t><t^ffY{4S*^>? 6 1 6^b^ffl*n5 

[0170] i^ijftiSL fefeS-y-T"* 

[0171] H*-&«*^»-/l'7 0 Oroifc^Sr^^ 

6KW-#-6. Mlfeft£*^^6 o o«t&ro*ft 
pi5,-fe-5?tl±, S^^yfe-^, fe^^yir-v 5 . 

io y-fe-i?as^*^5as, y-fe-v?l4, JS#£«a 

[0 17 2] Rm^y-fe-^Sfcli^^^^- V(73 

A-7 0 014. Ztl&.±0!Q ! mt£LX-M%lii1dF I F07 

[0173] yfe-^4rglt»ofc*Ktt, if 

*#dt*f=.-/i'7 0 01*, SESfc^tftf. fe^-fiic^ -7 

^^RJUaJctfT^r -*-lr*A«||iCtto-C. H 
20 Hi-g-j&;*:? 3 8ri^#y7"§ftfcfe:fc.fcLR^Wg 
tifi^-g-fritS. -trofg. *£*&iiSS'g'fi)i**y4 |, 3 8 

[0174] ®%<DlfeV* yfe-f SrS»t»ofcS*l- 
(4. HJR-S-ia^^a— ^7 0 014. W%&$.xf> y 9 3 
8A>f.fei^SHSWy7't5, fc£L. **y?3 

8*s^ w ^^ii^asroa»fli-4Sffiffl$n5o 

30 [0 1 7 5 ] g!E*tJW^-fi!cT7"B-f-|4, (Po 
rter, T) ioXXiyy (Du ff, T) f TCom 
positing Digital Images], 
Computer Graphics 16. Vol.18 
No. 3 . 1 9 8 4^. |&2 5 3~2 5 9"<— ^KgS 
— ^7#dt»»ro«*:, BS2 1 

KiMr. Lri>U r« i o sr^P-fTii, J; 

40 -Cfo6„ ^-ro^*, 7K-^-*3±t)5^7lcJ;-pX^SS$ 
[0176] fe#R)c> y-fe-v'&Slt^ofcBtKil^'g- 
[0177] fe^-fife^ ?/-fe-v!S:glt*ofc^|c, 

0 014. *-f. y-xcofet^a?(5JS 

«r^fi)ti-5o -lx»4, fe^fife^ V- 

50 i?x-&&ztiiz&t*&w&i!>mm£ft.. Kv-f-v- 



x • 77^ty h3*i/tV5»£Ktt. %<nlXib«)\z. i 

? yf 3 8#$T'fc5;i*b^ofci^ 

^ro^S^^y^saroft^gpA^w^^^ic: 10 
[0 17 8] y— ^wfe&^OTigfSlSc&x^r -r*— 

B^Sttfc^ 3 'RS'MSffi (so) & 
tt5y-^Ii7 0 2l;*t„ ^W* 7 0 2 
tt*<&ffl*S»4, H*7 0 2ro5££fc ; FSIPlfcl»#7 0 4 

K^7 0 2W 5*jT% ^KSBJ-Cfo?)i^-^$tl5gS 
»7 0 6fc*t. 8 7BK, *>«*SfJ*« (do) £* 



52 

fltSr^f -f*—>a >Ii7 1 O&T^-fo r*r-f 
Vai'lS*'? 1 orojpgft#«)«*tt. H^7 10C0 

^wsi4a»7 1 2 sr*i- 0 ihhuk, mm 7 1 0 

r±, S4(c3MW»7i 4£#-f5,, y-^B^7 0 

2*Jitj { f f ^f i -f*— v-g >-ii§f§7 1 on^mmm® 

fi, ja^tfofc&fc, S^ICifl:S«-r5 4:**S*i5. - 
*t&2-30>H*»:*— ^-i"f 7 l 6Sr, I7CC* 
i\ »SB3offl«**iffftU mu:tt, soX (1 
-do) BlS^t5r^7^-'>3^^7 
18, ffigt s o x do&ft5y-^ • t^tm*— > 
3^i7 2 0«i(Ji, (1-so) XdoBIM 
t5y-?^f^-->ay7 2 2i!tSW. £ 

g£ft3 0 T^f^^a^y-xffi«7 1 814, 

-y3yl«7 2 2lt, * rofe^f^r a ffe 

72014, ^My-^fii^f^-'yayfiJ) 
a^WH. ±-eiftWLfcfla»»^t«sin@», y 

ft, rftii, Mi^^yt-^.b©? 
^jft^-Klc-fcotig^ftS, i*I»m«Scro?*> 

«-85£, * 2 

[0179] 
[S3] 
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Oxlo 



r= threshold (dest,src) 
- threshold (six, dest) 



= luminance {dest, src) 



BLACKNESS 



NOTSRCERASE 



NOTSRCCOPY 



[0180] #H$Sci±> y-x&t3±Tfi?xT4*—y 

[0 18 1] Sf*^> yt-^'e,n7*77 • 
*A«»t#**4l-CV^. 7*77 ******* 

0'©*-/<-M7 i 6rt©#*ro««»5 few IOC 

[0 18 2] S^ro^ig^gfi, M^ro^iSW^w-g-ff- 

1**1-5 ^tt±^ XffMZ 4x5. 
[0 18 3] **rofi*3J:tf*aWStt» w*#«^* 

•y9 3 8tC7 P S'iy^$n2>o 

[0 184] in7Ur>a^!)Hi 5° 



= ckey(deM; "0 +/- o) 

Jiftt, Si / — K, ^By-KfeJ:0 t 2q{>'-KSr^tf* 

W*/'-K«rft-tf^^^7'L'yi/a 77 U -Tfc5. 
[0185] ffl*«g*tro sl-yf* * b t ro-g-rtro^K 

Vx.9 hit »#rafc^9 

[0186] 1211 7 A.*S.fctf[2l 7BIC, y-* (S) 

tf^T^-^a^ (d) wpflwa^w 2mmn 

*t5, 

[oi87] i. (a) $#T9?j7, (B) 



(29) 
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55 



56 



2. (A) StfST77M7\ (B) DfrT?7-<<7~ 

3. (A) StW7 9 ! r<c7*' (B) D # T ? X -< 7* 

4. (A) StfS#T?7V7\ (B) Difi#7*T4 

7% 



[0193] 7 97- 4^7- 4 ■ ^-TVKOjf^U^Ji 
©^-^fll^Sr. H 1 8 B Vl?-7iVB 1 0 t LT* 

^(OilB^W^-fy^S 1 4 (Next_Level) 



[0 18 81 *4tt, (NOP) *©«*!jsr-*4:«iflM-S**;*:/l'yV3l'5' 

*n5M*!fc5;i«rttf>U -?T(7>^*« 2il*« (S r c_Ac t i v e/De s t_a c t i 

7V7-J-7 - ^HCtt30OT*«a«***»#«E+a ve) fc*t75^8 0 6 (Sfctt, 3*tt±»3'!>- 



[0 18 9] tWg*, ^*y?3a (2«W0IJro > a V&ClT*-* 4rifc*S"f 5 d^i-? 5 ^ 8 1 

<Dlo£, ^^y*tJ:-orll«5-t-5£.5?*Sfca o CDS r c_a c t i v eJfcliDe s t„Ac live 

(C M£H85i+a*/<aaMI 77^8 0 614. zo>mMo>rf?4 ef^ls l 8 

^W*OVERS5»*ffiffl-t-5^^e>»* h i-fcfet, SU(7577^8 12 (data_in_*) tfi 

B^^!JyW^l:, ^nttHHC46*v». Lfl> ^ItbtlS. 75^8 1 2 fc S r c/D e s t_A c t 

»^7^K»r*7-f tTf-f ^fiK#U-C^SStL5!£4 20 t^?M *tS> ifwSSfc, 

^/Kcigffl$4x5^ y y7<r>®i&, !ft»t»*PU, 7 • 7 5^8 l Sri^ -t « J: ? ft Weft 1 . Sr l££&~t" 5 

foSt/^s ? h (^7^F) [0 194] Lfc7)5o-C, «i|»^y-Kl-ov>-C, P 

h^^ytfy^ (-tWStfl&fc*) SH^^fW ushftffsi:, =- KWD'e s t_a c t i 

[0190] ccoRgn^to-rsfc*^, *p/isa*-c f •f/ffcs^ltt^srtciSLt, asiws 

-y/Ko^jssp H ptLxfiv>x, ±x'm^tz{xm^m<om [0195] aisB-ett, r^f^W8 0 2 

[0 19 1] 01 8 Ale, K*WK3o«>»»fr^t», ls^j\s-7 9T4-7ikT--7'MZ'?^X±.X'$iWL1t : l& 

g|!#8 0 2f4. &3*ro#£w£«Ll'^A'WT*7V ^ht, ±-!?E59LfciT'lft5. SroglilCfco 

ft 2 g»»8 04(^(4, ^tl^tlCD T, f-^8 10» (y-*) VWfiTtWfc 

fcHftSte^ro^n^n^StL*. ^3gE^8 0 6 [0 19 6] l-K/KTjr^^^^b^^^btfcBft' 

(4, y-Ti • hSfcllT^^T 1 ^^— 40 It, Next_Level«1814ia 

h ftrnfen^^X-r ?T 4-7X-fo-&frZ0 oXftSna^tSi $tl5„ Da t a_i s_S 

jj>«rjp-f. ».li»»8 0 4K^*ix5*BB:, Hficttft r c77^8 1 6»«It(Si:t, S r c „A c t i v 

fiSg-fcrofcrot-f 5tf\ -troft^Otc, US u- e/D e s t_Ac t i v e 7y^8 0 6 

^/i" 7 9 7- 7/i"^(0#'(>9k-rZZktf /I't-flSixS. cwfSll, ^w^/KO^ffifc^fc; 

[0 19 2] S*?*4«)HcAoT, ftfero^g ^l, 2*sJ:tJ«3ro»||[as*ttS*v5. rUtt. u-</v 

.f-^8 0 0lt ^^7 ? -^^«^-t--5$*^* IF. ®^L*''i"7°*3J:t>'^^^^^7y if) tn: 



10 



/W8 1 0(^(4. ^roiH^^y_x^4it(47 J ^7'^^- 
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57 58 

l±, rftb^NULLd-fS ' t^T'#6 0 StTS. 

[0X9 7] & 5 y — K • l^/WOT ? 7V 7tt$l» [0 2 04] A ^S^ICT ? f 7fc£ ft AO 

[±, SnD~ op, SnDop, S^PDopWtM p 2 a (DVOVHTV T-<7it£ft,. Src_Ac 

*Vfl5da t a_i n79^»8 1 2t, Jtwy-K- I' t i v e7'7^8 0 6roK£l-SS*S^5„ S HD 7 

-<*0Src/Des t_active77/8 0 6C 7/8 1 2 iS-fey h*HTl>50t? (B^i£7^f.< 

iotft^S, i^?^UyV 3 y7!)-fflft»SfO 7T-(i^^»-C') . Nod e_Ac t i v e77^8 1 

It. :»7^K1iNode_Active77^8 c t i v e ««ftU:»f, Op 1 K/WS r 

1 SiLTEl^ih/C^S,, =_Ac t i v e 75/8 0 6 flHr 5/ h $ ft*. Da t 
[0 1 9 8] £©jli6(DJIr#W4«fe. Bl 9fc**H 10 a_is_Src816li. AOp 2 ^/VC'ty l-J 

5*?^7*l'yi'3^!)"8 3 EI20A *L*r.tK:B#SftfcV\ Opl^Hi^S rc.A 

*tfS-rS^fflT ^r-ftTV • X-7/U8 c t i v e fc (De s t_Ac t i v e) StfrtSW 

2ow^*t, t? (c*ssy«:r^7 l -f7'-ei±/j:v^f) . opi.ft 

[0 1 9 9] s#^l'j'f3^!)-a 3 Ott, ^ -<r>l"</i>-CT9T<c7it&]n.Z><, SHD riMrs/hi* 

7^KA, BjaiOtGW^-^rov^^U >"^£tttt ftT^SWC, Nod e_Ac t i v e 8 1 8^. Op 

U 7 y - 8 3 0 "Ctt lU^tOV^ty^W, Node_Act i v 

fcroHy'-K, PAGEil-CiStlW. PAGE e 8 1 8 <D Lfc <DX\ overKWSr 

ft, ttr^f-fyffo*), KftWafflflflife****, c_Act i v 679^8 0 6#-*y h£ft5„ ove 

Lfc^Sot, T^X-f ITf-f • ^-7^8 2 O^fj^BS r V-<yW± S r c_a c t ivetDes t_Ac t i 

20 v e (PAGE^icT?T^7#eo-c) 

[0200] BicttH/'- Kftro-e, rft<btt, -e, ove rttrow^w^f^ftsns. sn 

7/W8 2 0»fl£ffil"<A'&fl2»£U ^ft-^ft* 5 , -tft-e D^ityl-SJltWCNode.ActiveiS 

ftw^-T-w-^fS^^y^-wrs/^^^SIte^-t^ *y H£ft> Node_Ac t i ve»«IttfltL4; 

c^ft^ft^^ffiiKoHy-K^Of, *fC*s^r^ *3 8f±, ro«Te. F-7>8 2 o*»b*4T*, 

Sft. *«<?^KCK*M-*«llil«4v»»-C. S~nD H2 0Bfc***vfcfc«K*a. 

opttNOPKW, da t a_i n_*o p77^8 [ 0 2 0 5 ] 0 2 0 C o t, B*W*CT*7-<f 7fc 

1 2, Ne x t_Le v e 1 77^8 1 4*'iOTa t £ft3i§3\ SHD *S-fe y h $ft"C^5 (1^1* ftfc# 

a_i s_S r c77^8 1 6 fcSff$ft'5 0 rf^f iDttBWS*^) WC, ^OW^Pu sh Bi«T 
KBtt, *h»-*-W«*t»fcbi-. 30 ^f^/ft^5. Node_Activ e 818lt, 

[0 20 1] Ti'r^f-f ■7-^8 2 0Bft«l/ :©l/'<A'l:oV^ty^ft5. Node_Acti 

*W±, £<0*y-^t*ftfc#£+S***Op.2 v eW^SS^fbLtW-e, AOp2^/l'«De s t 

(Cto-C^SftS. ^Wl^l^T* 7^7^81* 8 _Active77W^SW. AOp 

bi:icrthW«Sh5Aop2Bt*8S- 7{bSft5. SIIDiity hSft-CV^Sro-e, Node 

nDopfc-fctfSriDo pro*ft*ft*ffl^TJE*r3*t _Ac t i v ett-fey ha#lfc**C40 . No d e_ 

5„ SlOp 2tt, Sro^-^SrlMti-S^WefcO, Ac t i v e«Ili, AOp2aKBLTIi*ftL4 

^ftts, D^r^7 i -f7-c?S/!»sr^7 1 -<7-c4v> (f* v\ i^iroftHttSBSUftv*. ^^^38 

^^^^.fr-f tCioTS^ftS. « [020 6 ] B120E»>b*>A»5J;9t, C#RKT* 

[0 2 0 2] f-7**8 2 0»ftmi"<*« < O p 1 K 7M 7<fc£ ft«»-&, ^A-T'P u s h ClfiT V 

B8U T^f^ftSSSO 4W*ftW«ti3ttfc 7M7<b£ft5. SttT/T^ffc^ DI4»BM*4 

gla, btiiOcm »^ov 6 fC w-e. No de_Ac-t i ve8 18li, £«>1"</HC 

tt. PAGEWtT^r-fT'W, SnD _ opi ^Tt7h^5. Noie_active«ftL 

S — flDo p tt, ^^y^t/y/'aJftSNOPH fcC0T\ O p 1 U"</KPD est_Act ive77^ 

fclbf. WiSSSnDoprtm, overW iSS-feyhSft5. O p 1 b 1fiT 9 f 4 7 it £ft5WT\ 

?7V7Kfc5. Op 1 att#7*T-r7{b£ft5„ SnDnf-ft** 

[0 2 0 3] rW^ICO^-C, A, B*iJ:rj«C*S, S$ y h£ftT^5«T\ Nod e_Ac t i v e ttir V h 

Ii#7^7^tib0, rftfeW^^^K^, *W Sftfc*Sfc*6. Opl WIJNo de_Ac t 
!«£7*T*7fb$ft5*£fcWig£5a**8 50 iveWbUVW, rftfiUirofcHfl^grfc 
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S„ %f$.x? -y? 3 8(4, 



2 OFCSSJifctwc* 



[0 2 0 71 CCQ^MI(4, H 1 9»i^/Uy-/3 >• 

^^^r^^^^ik^B o 2fc±t/r?f^iff^ • 
j/a-i-s r box-* s $ 

%X'ifeiLiSft,Z>T?=r4 ¥=r 4 • Y—y^a 2 O&fcfc 

^^y^felitf+srii^sa. as* 

[0 2 0 8] 5 64577^, awSSlCioTTi'f 
-f^bl" 3- £«T-£3 s r c_i s_l e a f_n o 
deB(d77yi:, dest_is_PAGE (St7 20 

ffl»75m *fflfcfcS<rtBttja**«::£ 
C *6tcBSE$^fcV\ d e s t_i s_PAGE(D 
»g\ s od — «»£tttt*flcJS4L*v*ro-i?. in* 
ffitt'tsr i rtSRTfg-efcS, 
[0 2 0 9] ±T?tt, 7Cf^ fc'T-f • 2 0 

as, x^T'ur^r^D-s 3 o<75^it(c:S'Jv>-c 
ifro.fc7K:#36iSft, yj-8 3 oco$s 

.fcM^TSftS (-$-&;b*>£ti&*ft3) a»**L 
fc. f-^8 2 0»M«4MT'li, Rfc&T^TM so 
T'fti^rflBiieitSIMrRWi-fifc*^ 7 2 ( = 2x2x 
3X3X2) j@ro**y*«jgas*C5T^fe& 5 fo3„ 
rtO^f, 3H+8 02, 806, 81 2, 814, 81 
6*3J;tf8 l 8 ©IftSfFflfiris , 

[0210] tt#jSS?*i, a^T^-T'/U t LTfltfK 

S*i3©-Ctttt< , 7^f^f^ 7— ^a-s 2 o 

7 ^8 3 Ofc-ij-jlSClitfTf 3. 40 
Id, @5fe»lte^^3-^5 1 2*J4.U<5 1 4 #11^22 

Mftlfiftfc'H- -m# < , 7?t-{ :/<b?£3i: 1 3WiT?S 5 
J; 5 (eft D , &#(4, ^^a-^eoo^Pj^ffl^tifc 
0 0 ± 3f¥ffiW 
fcfcldS^lt^^y^ 3 8(c^ (SriiWfc) £ft 
•5, r»J:9 fcgfigfc, 02 OGfcfiSflgW^ia^-rs. 
[0 2 11] *-£>ftb?H£, ^2 0HKttS«eWlc^$n 
-CV3J: 51-, 7fr4 fcTr -f • -r— :/^8 2 0;$\ U- 



P. r©J: iiu^ht?y-/7- 
tf?^ H<o?i|£\ 7*7-4 e'TV ■ r— ^Vus 2 0 
ft, U"</W •7 97-<(7{k7— •7*/U5 3 0 *»&W»&-r5 
rirriST't So 02 0 I (C^tfjK^ftTV^S'b 5 1 
0<Dft#«fi!c-ti±, 7 97- 4^7- 4 •f-7*/l'8 2 0 
;js, u~<^ • r^x-f y<b-r— T*/^ 3 onSCfcS. 

7^7^7ftf- ^/W5 3 0(c:^£;h,3coT\ 7 
?f^f-f x-y^8 2 0*>bWI«1-5-i:!i s -C§ 
S„ W f^-f • 7 L -7>8 2 O^IS 2 0At*J 

7*7-4 -fitT—/)^ 5 3 0 fc*fti"« Z t MX- # 5. 
[0212] 7 * 7~ 4 f7 -f •X-7'/W8 2 0*54.tf* 

AMWi^^H)-Ai4 (E13#Ra) 
ffi3-|*tv ! ; J .-/U7 0 0(4, ffiftflHSt&S, U^-7 

97-4 7-tt.&x.vmt\,®ife<nmjkb L-c»s*ns)H 

[0 2 1 3] Hi[tffl7j*i^-A'8 0 0<7>»lf£fc, -ft 

[0 2 14] WaftU^Jj* yt-^gltRofceC H 
^(±173*^^—^8 0 0(4, W^^iattL, ^Wli^?: 

(4, S«(C|B1gLfcliiS*S, Rffi^y-fe-^feW*^ 
y Met oXm^S^S 13 Scfc'tt, tti^8 9 8l:!Sgg 
^S„ -rx- ^-fv-©^ 1 ?^ y-fc-yfcSttRofc 
^t(4, Wsgai 73*^3.-^8 0 0(4, ■tro^y-fe-v' 
4r J troffl7jlijS+. 

[0215] W7J8 9 8(4, iK-StCJCCT, HSHtSx 

fcSlfit-14, fr^-iS*^-y hSfctt^y >fit£f<n 

T, AyF • ^ hT*fcl47W— A • Xb7t:-$ts¥m 
*RAM4i?»>* *fc(4, =ytr»-# 

[0 2 16] CiStftRWL-Ctfci/^^AioSaSK: 

iii-S^SWSffiSr^r-tSS**^tf^7'-X i i' hro^ 

<O^W*Cia-C', ^^r^X • 7-rx(^ofc, ^7"v?i 

chw5*>wio4 fc(4« m>7 vt-4? x'ft^<m^ 

iro3l»^-r'<7)- : ero^?a(4, ^-^ — y7-g-fi)J(cf* 



5„ l*>u Tx-&mimwirz*mw<Dmmte, m» 

[0217] tiili, SP AGE*- (A in B) 
over (C out D) over PAGEI^® 
2 2l'^$nfc2il**igl OOOtLr*i-r<t75S ? 

a, b, cloths, ia, «*ffiifeii 

{£*5 i OT5§ ft If- * K £ o T £Jg * ft 3 lift 3 7 

f^7'ftf-7'/H0 0 1«;I2 3t*t s 023t 
(4, ft 1 0 0 2T\ 12 2(C*£;}"lfc3;tf)C out 

fc, outisSSI^, DT?(*fc< PAGECttLT^jEK 

vtK &tiL&ftx'o v e r mn<n&msm<n<m^mti 

ftS-f^tco*^:/ • =?4 y«'>&< th-^X-ftT 
9** -7*\z.t}. % t i . ^ ftttfclBUBfc* 5 BrtBtt* 

[0218] r wfai®*5EflBi-5*-ffiro i oris,- saw 
±.<DmKmm-ti>t, 2ii*ioooK)#siy-K (-t 

fcfc*,A, B, CiJiOlD) It, 0 2 4*3iO<02 5fc: 

(over) h*B<*te«fcSft3. 
[02 19] H24-C'f4, 2o«W7 

B ?*£^U G2I4, CfciWDOW 

^^yVayyu-ioooTi 

•</u • r * r 7 l 0 0 5 &0 2 6 

u-^/v • r^^^^b^-^/n 005 fc'gJE£ftfc^ 

^/l/yv'ayyJ-lO 0 4rt>e>WSfcft3i*5 
fcUroJifln&fcfc&l-. rftli. ^ 

ftsa^-efcs. s&ftjKiiiSSfts. s^cin^y 

y^ftStti^WUL-cti, rixe>roSS»ii, *9v9 
[0 2 2 0] ii^w^«r®P>1-*&wiott, #9*- 



(32) 2000-149035 

X&Z, b*bmw*7i> = t b<affl<D 

o v e ri&JSt±, 'btt-'^FSIK&S. ? y y 

[0 2 2 1 ] A*}±CJ«B(Ci5SW^y^^Gl«^y 

10 0 02 7K*-*". rro*gX-i4, 1 BUS 

KoV>T, ItWoveriiifflLTA, B, C*3 
£TOiWf-fy^JH61^»l 2®<75^^y^jagL 
fclttSLT, 8ow^ *i8£fc*tta s ^fT£ft5C:i: 

3M¥£ftfcv\, 
[0 2 2 2 ] lo*fttt«tOl<t!)&5*7 r ^i'r 

20 -fSSfSL-V^ifeSr, r^A»f>Si^-f-5. 0 2 81c** 
ftfc0H£#JS-f5i:, SSC out Dli S«cn 
D — , cnD&itFC^nDW-tft-eftlCo^-tlo-f 

fct, C out D*l|tfr»81-6*Jto«ie«Tf* 
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1. Title of the Invention 

PROCESSING GRAPHIC OBJECTS FOR FAST RASTERISED RENDERING 

2. Claims 

1. A method of processing graphic objects intended lo form a raster pixel image, 
said processing comprising a process for determining an intersection order between edges 
of said graphic objects by evaluating corresponding edge records for a current scan line in 
rasterised display order and determining an edge intersection value for each said edge for 
a subsequent scan line, said process comprising, during processing of said edge records, 
the steps of: 

retaining a limited number of processed edge records in an unordered first buffer 
and progressively transferring said processed edge records to a second buffer in order, as 
orderable processed edge records are added to said fust buffer; 

transferring unordcrablc processed edge records to a third buffer in order to order 
said edge records in said third buffer; and 

selectively processing edge records from said second and third buffers for 
determining ordered intersections for a subsequent scan line. 

2. A method according to claim 1, wherein said ordering of said edge records in said 
third buffer occurs upon adding said edges to said third buffer. 

3. A method according to claim 2, wherein said edge records are insertion sorted into 
said third buffer. 

4. A method according to claim 3, wherein edges in said third buffer are ordered on 
completion of processing of said current scan line. 

5. A method according to claim 2, wherein said second and third buffers are 
combined to form respective portions of a fourth buffer used for said selective processing, 
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whereby ordered edges from said portions are progressively compared to determine a next 
edge for said processing. 

6. A method according to claim 5, wherein on completion of processing said current 
scan line, contents of said second and third buffers are swapped to said fourth buffer. 

7. A method according to claim 6, wherein said second, third and fourth buffers each 
include pointers to start and end locations thereof and at an end of said current scan line 
the pointers are swapped to swap the buffers. 

8. A method according to claim 1 wherein said first buffer comprises an edge pool 
formed in a memory, said method comprising the step of determining from a plurality of 
active edge records farmed in said memory, active edge values for said current scanline 
and to transfer, for each said active edge value, the corresponding edge record to said 
edge pooL 

9. A method according to claim 8 wherein said second buffer comprises a current 
edge output list formed in said memory, said method comprising, for each said active 
edge value, the step of examining records in said edge pool and said corresponding edge 
record and to transfer an ordered one of said edge records to said current edge list 

10. A method according to claim 9 wherein said third buffer comprises a current 
spill output list formed in said memory, said method comprising the step of transferring in 
order to said current spill list, edge records from said edge pool not able to be ordered into 
said current edge list. 



11. A method according to claim 10 wherein said said method comprising, on 
completion of processing said current scanline, the steps of flushing edge records from 
said edge pool in order to a corresponding one of said output lists, whereupon said output 



lists are assigned as a current edge input list and a current edge input spill list, 
respectively, for processing of said subsequent scanline, and transferring edge records in 
order from said input lists to corresponding ones of said active edge records for 
determination of said active edge values tor said subsequent scanline. 



12. A method of processing graphic objects intended to form a raster pixel image in a 
graphic object rendering system, said processing comprising a first process for 
determining an intersection order between edges of said graphic objects and a current 
scan line of said raster pixel image, said system comprising: 

plural edge records for each of a current scan line and a subsequent scan line, each 
of said records including a plurality of record locations for retaining at least a pixel 
location value of a corresponding edge on the corresponding scan line, each of said 
current and subsequent edge records being divided into at least a main portion and a spill 
portion, at least the main portion of said current edge records being arranged in raster 
pixel order; 

at least one current active edge record; 
a spill active edge record, and 

a pool including a limited predetermined number of edge records; 
said method comprising the steps of. 

(a) transferring a first edge record from each of said main and spill portions of 
said current edge records into the corresponding active edge records; 

(b) comparing values of said active edge records to determine that said active 
edge record having a lowest value in said raster pixel order and outputting lhat value and 
record as a current edge value and record; 

(c) updating said current edge record with a value of the corresponding edge for 
said subsequent scan line; 

(d) comparing the updated edge value with edge values within said pool, 
wherein if the updated edge value is less than an edge value in said pool then 
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(da) said updated current edge record is transferred to tbe spill portion of 
the subsequent edge records; otherwise 

(db) (dba) an edge record having a smallest edge value is transferred from 
said pool to a next record of the main portion of said subsequent edge record; and 

(dbb) said updated edge record is transferred to the record of said pool 
vacated in sub-step (dba); and 

(dc) a further edge record is transferred from the corresponding portion of 
the current edge record to the active edge record vacated by the updated edge record; 

(e) repeating steps (b) to (d) until each of said records in said pool are occupied 
whereupon a smallest edge value record of said pool is transferred to said main portion of 
said subsequent edge records; 

(t) repeating steps (b) to (e) until all records of said current records have been 
updated, and then flushing records from said pool in order to respective next records 
within said main portion of said subsequent records; 

(g) sorting said records in said spill portion of said subsequent records into 
raster pixel order; 

(h) transferring said subsequent edge records to said current edge records; and . 

(i) repeating steps (a) to <h) for each further scan line of said raster pixel image. 

13. A method according to claim 12, wherein step (g) is performed when Step (da) is 
performed. 

14. A method according to claim 12, wherein step (g) is performed by a software 
sorting routine. 

15. A method according to claim 12, wherein step (h) is performed by swapping 
memory locations pointing to said current edge records and said subsequent edge records. 
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16. A method according to claim 12, wherein said active edge records further include 
a new active edge record for receiving from a corresponding new edge records, records of 
edges commencing on said current scan line, and wherein step (b) comprises comparing 
each of said new, current and spill active edge records to determine that with said lowest 
value. 

17. A method according to claim 12, wherein step (d), said updated edge value is 
compared with an immediately preceding updated edge value most recently added to said 
pool. 

18. Apparatus for processing graphic objects intended to form a raster pixel image, 
said processing comprising a process for determining an intersection order between, edges 
of said graphic objects by evaluating corresponding edge records for a current scanline in 
rasterised display order and determining an edge intersection value for each said edge for 
a subsequent scanline, said apparatus comprising: 

a memory having an unordered first buffer, a second buffer and a third buffer; 

and 

a processor for retaining a limited number of processed edge records in said 
unordered first buffer, for progressively transferring said processed edge records to said 
second buffer in order, as ordcrable processed edge records are added to said first buffer, 
for transferring unorderable processed edge records to said third buffer in order to order 
said edge records in said third buffer, and for selectively processing edge records from 
said second and third buffers for determining ordered intersections for a subsequent 
scanline. 

19. Apparatus according to claim 18 wherein said first buffer comprises an edge 
pool, said processor being configured to determine from a plurality of active edge records 
formed in said memory, active edge values for said current scanline and to transfer, for 
each said active edge value, the corresponding edge record to said edge pool. 
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20. Apparatus according to claim 19 wherein said second buffer comprises a current 
edge oulput list, said processor being configured, for each said active edge value, to 
examine records in said edge pool and said corresponding edge record and to transfer an 
ordered one of said edge records to said current edge list. 

21. Apparatus according to claim 20 wherein said third buffer comprises a current 
spill output list, said processor being configured to transfer in order to said current spill 
list, edge records from said edge pool not able to be ordered into said current edge list. 

22. Apparatus according to claim 21 wherein said processor is configured, on 
completion of processing said current scan line, for flushing edge records from said edge 
pool in order to a corresponding one of said output lists, whereupon said output lists are 
assigned as a current edge input list and a current edge input spill list, respectively, for 
processing of said subsequent scamine, and for transferring edge records in order from 
said input lists to corresponding ones of said active edge records for determination of said 
active edge values for said subsequent scanline 

23. Apparatus for processing graphic objects intended to form a raster pixel image, 
said processing comprising a process for determining an intersection order between edges 
of said graphic objects by evaluating corresponding edge records for a current scan line in 
tasterised display order and determining an edge intersection value for each said edge for 
a subsequent scan line, said apparatus comprising: 

means for retaining a limited number of processed edge records in an unordered 
first buffer and progressively transferring said processed edge records to a second buffer 
in order, as orderable processed edge records are added to said first buffer; 

means for transferring unorderable processed edge records to a third buffer in 
order to order said edge records in said third buffer, and 

means for selectively processing edge records from said second and third buffers 
for determining ordered intersections for a subsequent scan line. 
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24. Apparatus forming part of a graphic object rendering system for processing 
graphic objects intended to form a raster pixel image, said processing comprising a first 
process for determining an intersection order between edges of said graphic objects and a 
current scan line of said raster pixel image, said apparatus comprising: 

plural edge records for each of a current scan line and a subsequent scan line, each 
of said records including a plurality of record locations for retaining at least a pixel 
location value of a corresponding edge on the corresponding scan line, each of said 
current and subsequent edge records being divided into at least a main portion and a spfll 
portion, at least the main portion of said current edge records being arranged in raster 
pixel order; 

at least one current active edge record; 
a spill active edge record; 

a pool including a limited predetermined number of edge records; and an 
edge record processing arrangement for: 

(a) transferring a first edge record from each of said main and spill portions of 
said current edge records into the corresponding active edge records; 

(b) comparing values of said active edge records to determine that said active 
edge record having a lowest value in said raster pixel order and outputting that value and 
record as a current edge value and record; 

(c) updating said current edge record with a value of the corresponding edge for 
said subsequent scan line; 

(d) comparing the updated edge value with edge values within said pool, 
wherein if the updated edge value is less than an edge value in said pool then 

(da) said updated current edge record is transferred to the spill portion of 
the subsequent edge records; otherwise 

(db) (dba) an edge record having a smallest edge value is transferred from 
said pool to a next record of the main portion of said subsequent edge record; and 
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(dbb) said updated edge record is transferred to the record of said pool 
vacated in sub-step (dba); and 

(dc) a further edge record is transferred from the corresponding portion of 
the current edge record to the active edge record vacated by the updated edge record; 

(e) repeating Steps (b) to (d) until each of said records in said pool are occupied 
whereupon a smallest edge value record of said pool is transferred to said main portion of 
said subsequent edge records; 

(f) repeating steps (b) to (e) until all records of said current records have been 
updated, and then flushing records from said pool in order to respective next records 
within said main portion of said subsequent records; 

(g) sorting said records in said spill portion of said subsequent records into 
raster pixel order; 

(h) transferring said subsequent edge records to said current edge records; and 

(i) repeating steps (a) to (h) for each further scan line of said raster pixel image. 

25. A computer readable memory medium for storing a program for apparatus which 
processes graphic objects intended to form a raster pixel image, said processing 
comprising a process for determining an intersection order between edges of said graphic 
objects by evaluating corresponding edge records for a current scan line in rasterised 
display order and determining an edge intersection value for each said edge for a 
subsequent scan line, said program comprising: 

■ code for a retaining step for retaining a limited number of processed edge records 
in an unordered first buffer and progressively transferring said processed edge records to 
a second buffer in order, as otderable processed edge records are added to said first 
buffer; 

code for a transfer step for transferring unorderable processed edge records to a 
third buffer in order to order said edge records in said third buffer; and 

•code for a process step for selectively processing edge records from said second 
and third buffers for determining ordered intersections for a subsequent scan line. 
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26. A computer readable medium comprising a computer program product for 
processing graphic objects intended to form a raster pixel image in a graphic object 
rendering system, said processing comprising a first process for determining an 
intersection order between edges of said graphic objects and a current scan line of said 
raster pixel image, said computer program product being associated with: 

plural edge records for each of a current scan line and a subsequent scan line, each 
of said records including a plurality of record locations for retaining at least a pixel 
location value of a corresponding edge on the corresponding scan line, each of said 
current and subsequent edge records being divided into at least a main portion and a spill 
portion, at least the main portion of said current edge records being arranged in raster 
pixel order; 

at least one current active edge record; 
a spill active edge record, and 

a pool including a limited predetermined number of edge records; 
said first process being configured to implement the steps of: 

(a) transferring a first edge record from each of said main and spill portions of 
said current edge records into the corresponding active edge records; 

(b) comparing values of said active edge records to determine that said active 
edge record having a lowest value in said raster pixel order and outputting that value and 
record as a current edge value and record; 

(c) updating said current edge record with a value of the corresponding edge for 
said subsequent scan line; 

(d) comparing the updated edge value with edge values within said pool, 
wherein if the updated edge value is less than an edge value in said pool then 

(da) said updated current edge record is transferred to the spill portion of 
the subsequent edge records; otherwise 

(db) (dba) an edge record having a smallest edge value is transferred from 
said pool to a next record of the main portion of said subsequent edge record; and 
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(dbb) said updated edge record is transferred to the record of said pool 
vacated in sub-step (dba); and 

(dc) a further edge record is transferred from the corresponding portion of 
the current edge record to the active edge record vacated by (he updated edge record; 

(e) repeating steps (b) to (d) until each of said records in said pool are occupied 
whereupon a smallest edge value record of said pool is transferred to said main portion of 
said subsequent edge records; 

(f) repeating steps (b) to (e) until all records of said current records have been 
updated, and then flushing records from said pool in order to respective next records 
within said main portion of said subsequent records; 

(g) sorting said records in said spill portion of said subsequent records into 
raster pixel order; 

(h) transferring said subsequent edge records to said current edge records; and 

(i) repeating steps (a) to (h) for each further scan line of said raster pixel image. 

27. A method according to claim 1 or 12, said processing comprising a (second) 
process for reproducing pixel image data defined by at least one said graphic object 
forming part of said image, said image being rendered in a rasteriscd fashion, said method 
comprising the steps of: 

(j) establishing a plurality of graphic object fill types distinguishable by at least 
one property of each type; 

(k) receiving a graphic object requiring rendering, determining the 
corresponding fill type and using the determined fill type to access a filling record 
associated with said graphic object; and 

(1) performing a filling process associated with said filling record to determine 
said pixel image data in a rasterised fashion corresponding to said graphic object. 



28. A method according to claim 27, wherein one of said types is a raster image type 
and if said object has a fill type identifying a raster image type object, step (i) comprises 
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using a pixel location in said image to determine a mapping to said pixel image data 
whereupon that data so mapped is selected for output at said pixel location. 

29. A method according to claim 27, wherein said mapping includes an affiae 
transform of said pixel image data. 

30. A method according to claim 27 wherein said mapping performs a texture 
mapping of pixel image data to said raster image. 

31. A method according to claim 27, wherein a pixel location in said raster image to 
be rendered is used to access an entry in a table, said table including a reference to a 
component of said pixel image data to be rendered within said graphic object, said second 
process further comprising manipulating said reference to access part of said pixel image 
data which is then used to contribute to a rendered pixel value of said raster image at said 
pixel location. 

32. A method according to claim 31, wherein the contribution of said pixel image data 
comprises a single pixel data value that is reproduced in said raster image. 

33. A method according to claim 31, wherein the contribution of said pixel image data 
comprises at least one pixel data value that is composited with at least one value derived 
from at least one other graphic object within said raster image to derive a single pixel 
value that is reproduced in said rasterised image. . 

34. A method according to claim 31, wherein the contribution of said pixel image data 
comprises one pixel data value that is composited with at least one value derived from at 
least one other graphic object within said raster image to derive a plurality of pixel values 
that arc reproduced in said rasterised image. 
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35. A method according to claim 28, wherein said mapping includes interpolating a 
plurality of pixel image daia located about* mapped location within said pixel image data. 

36. A method according to claim 27, wherein step (k) comprises the sub-step of: 

(ka) developing a stack of values corresponding to each said (different) pixel on 
a scan line of said raster image from data sourced from a table of compositing properties 
ordered according to object priorities, said stack having a depth corresponding to a 
number of said objects active at said pixel location,; 

and wherein step (0 comprises the snb-step of: 

(ia) determining a pixel value at said pixel location using the corresponding said 

stack. 

37. A method according to claim 1 or 12, wherein each said graphic object is 
described by a data structure comprising at least one edge that defines at least part of a 
boundary of said object, said edge including a plurality of segments described by segment 
descriptions and extending between starting and ending scan lines of said edge 
characterised in that at least two of said segments are defined by differing data formats. 

38. A method according to claim 37, wherein, at a connection between said segments, 
a value returned by a first rendered one of said segments is used as an initial determining 
value for the following one of said segments. ; 

39. A method according to claim 37, wherein each said data format includes 
identifiers for a start and an end of said segment and further parameters permitting 
determination of said segment 

40. A method according to Claim 39, wherein said segment is an orthogonal step 
segment and said further parameters include a signed x-step value and an unsigned y-step 
value. 
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41. A method according to claim 39, wherein said segment is a straight line inclined 
to a scan line direction and said further parameters include a first order value for adding 
to a pixel location value of a current scan line to derive a pixel location value for a 
following scan line. 

42. A method according to claim 39, wherein said segment is a quadratic curve and 
said further parameters include a first order value associated with a current scan line for 
adding to a pixel location value of said current scan line to derive a pixel location value 
for a following scan line, and a second order value for adding to the first order value of 
said current scan line to derive a first order value for the following scan line. 

43. A method according to claim 39, wherein said segment is an N-th order 
polynomial curve and said further parameters include 1 to N order values associated with 
a current scan line for determining, by adding, a pixel location value of said current scan 
line to derive a pixel location value for a following scan line, and 1 to (N-l) order values 
for the following scan line. 

44. A method according to claim 1 or 12, said processing comprising a third process 
for rendering a segment, edge, said method including the steps of interpreting plural 
segment data types and evaluating pixel locations on said edge for each of said segments 
by manipulating the corresponding segment data types characterised by a seamless 
transition from one said segment to an adjoining said segment resulting From a 
terminating pixel location of a first segment is used to determine a following pixel 
location for the fallowing said segment. 

45. A method according to claim 1 or 12, said processing comprising a fourth process 
for compositing first and second pixel values each having corresponding color and 
opacity values, said fourth process comprising the steps of: 
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fj) dividing each of said pixel values to define at least Iwo regions theieof, a 
first being a fully opaque region and another being a fully transparent region; 

(k) determining areas of intersection between each of said regions to thus derive 
a opacity value for each of the intersecting regions; 

(1) selecting at least one of the regions as contributing color and opacity to a 
composited pixel value; 

(m) determining the colors of the selected regions according to a predetermined 
raster operation; and 

(n) forming a first sum of color-opacity products for the selected regions and 
dividing said first sum by a second sum of the opacities of the selected regions to derive a 
color value of said composited pixel, said second sum being an opacity of said 
composited pixel. 

46. A method according to claim 45, wherein the regions of one of said first or second 
pixel values are arranged orthogonal to those of the other said second or first pixel values 
to define three intersecting regions of interest upon which steps (1) to (n) are applied. 

47. A method according to claim 46, wbeiein said compositing, operation comprises 
identifying at least one of said regions of interest and using said identified regions) of 
interest in said sums. 

48. A method according to claim 45 wherein any one of steps 0) to (I) comprises the 
step of normalising said color and opacity values. 

49. A method according to claim 48, wherein step (m) comprises using the normalised 
opacity value to delineate the corresponding said regions. 
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50. A method' according to claim 1 or 12, said processing comprising a fourth process 
for compositing a source color and opacity (so) with a destination color and opacity (do), 
said fourth process comprising the steps of: 

(j) normalising the color and opacity values for each of said source and 
destination to define at least two regions thereof, a first being a fully opaque region 
{(so),(do)} and another being a fully transparent region {(l-so),(l-do)}; 

(k) orthogonally arranging the destination regions to intersect the source regions 
to derive a opacity value for each of each of three intersecting regions, those being 

(i) source outside destination {so x (Wo)}; 

(ii) ' source intersect destination {so xdo); and 
(Hi) destination outside source {(1-so) x do}; 

(1) determining a source intersect destination (sc x dc) color value as an opaque 
component of a composited pixel value according to a predetermined raster operation; 

(m) determining an opacity component of said composited pixel value using a 
sum Of selected color-opacity products, those being: , 

sc(sox(l-do)) , (soxdoXscropdc) , and dc((l-so)xdo), 
where rop represents said predetermined raster operation. 

51. A method according to claim 50, wherein said color-opacity products are 
selectable according to a predetermined opacity compositing operation. 

52. A method according to claim 51, wherein said predetermined opacity compositing 
operation comprises a flag corresponding to each of said intersecting regions and said 
sum is determined as the sum of the areas of those said intersecting regions for which the 
corresponding said flag is set. 

53. A method according to claim 1 or 12, said processing comprising a fourth process 
for compositing first and second pixel values, each having corresponding color and 
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opacity values, according lo a predetermined compositing operation, to form a 
composited pixel value, said fourth process comprising the steps of: 

(j) dividing each of said pixel values to define at least two regions thereof, a 
first being a fully opaque region and another being a fully transparent region; 

(k) determining areas of intersection between each of said regions to thus derive 
a opacity value for each of the intersecting regions; 

(1) selecting according to said compositing operation at least one of the regions 
as contributing color and opacity to said composited pixel value; 

(m) determining a color of each said selected region according to a 
predetermined raster operation being part of said compositing operation; and 

(n) forming, according to a predetermined opacity operation being part oE said 
compositing operation, a first sum of color-opacity products of said selected regions and 
dividing said first sum by a second sum of the opacities of said selected regions to derive 
a color value of said composited pixel value, said second sum being an opacity of said 
composited pixel, wherein said opacity operation comprises a flag corresponding to each 
of said regions and said first sum is determined as the sum of the areas of those said 
regions for which the corresponding said flag is set 

54. A method according to claim 1 or 12, further comprising compositing graphic 
objects characterised by raster operations between said objects that account for 
transparency components of each of said objects: 

55. A method according to claim 1 or 12, said processing comprising a fifth process 
for applying a compositing expression to said graphical object environment, said 
compositing expression having a plurality of priority levels, said fifth process comprising, 
for each priority level, in ascending priority order, the steps of: 

identifying a plurality of alternative actions available to arise from an operation 
associated with at least one operand of said priority level; 
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associating said alternate actions with a plurality of activation conditions for said 
priority level, said activation conditions including an activity state of each said operand; 

logically combining said activation conditions to select one of said alternate 
actions for determination and application to a next higher priority level. 

56. A method according to claim 55, wherein said activation conditions include at 
least one flag indicating a corresponding condition foe which said operation provides data, 
a pointer, to an entry for a subsequent operation which uses said data, and at least one flag 
to indicate which said operand provides said data. 

57. A method according to daim 55, wherein said compositing expression is 
evaluated by rendering said selected alternate actions in ascending priority order. 

58. A method according to claim 57, wherein each said alternate action comprises a 
stack operation, said stack operations together determining pixel output values for a span 
of pixels between two object edges on a scan line. 

59. A method according to claim 55, wherein said cpmposituig expression is a 
hierarchically structured representation of said image. 

60. A method according to claim 58, wherein said compositing expression is 
optimised in regard to the number of pixel operations required to render said image 
represented by said compositing expression. 

61. A method according to claim 60, wherein said logical combining of said activation 
conditions comprises modifying a manner in which said compositing expression is 
evaluated without modifying said hierarchically structured representation. 



(69) 



WBH 2 0 0 0 -1 



62. A [method according to claim 59, wherein said image comprises at least a pixel 
based image component. 

63. A method according to claim 55, wherein a wholly opaque graphical object at a 
particular priority level acts to eliminate one or more objects at lower priority levels of 
said compositing expression. 

64. A method according to claim 54, wherein at least one of said steps comprises 
fanning a table of said alternate actions and said activation conditions. 

65. A method according to claim 1 or 12, said processing comprising a fifth process 
for formiDg an optimised compositing expression, said compositing expression being a 
hierarchically structured representation of an arrangement of said graphical objects, 
wherein each said graphical object has a predetermined outline, said fifth process 
comprising the steps of: 

detemiining an expression tor a plurality of regions, each said region being 
defined by at least one region outline substantially following at least one of said 
predetermined outlines or parts thereof; 

identifying a plurality of further regions depending on at least one characteristic of 
at least one of said regions, wherein each said further region has an associated 
compositing operation; 

logically combining said further regions and said associated compositing 
operations; and 

applying said logical combination to a higher level of said hierarchically 
structured representation to form said optimised compositing expression. 

66. A method according to claim 65, wherein at least one of said steps comprises 
forming a table of said alternate actions and said activation conditions. 
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67. A method according to claim 1 or 12, said processing comprising a fifth process 
far forming a stack of compositing operations used for the rendering of said image, said 
fifth process comprising the steps of: 

establishing a table arranged according to a priority level at which each said 
graphical object is reproducible, said table including for each said priority level: 

(i) entries for a plurality of alternate actions available to arise from an operation 
associated with at least one operand at said priority level; and 

(ii) entries for activation conditions including an activity state for each said 
operand; 

updating said entries for a span of displayable pixels between two adjacent object 
edges on a displayable scan lines and for each said span 

analysing said activation conditions to select one of said alternate actions for each 
said priority level for transfer in ascending priority order to said stack. 

58. A method according to claim 1 or 12, said processing comprising a sixth process 
for generating a compositing stack for use in rendering said image formed of a plurality of 
graphic objects, each of the graphic objects being described by components including at 
least an edge and a viewing priority relative to the other graphic objects, the sixth process 
comprising the steps of: 

(j) determining the boundaries of said objects and intersections therebetween; 
" (k) for each said intersection so determined, providing a level activation table of 
objects active at said intersection arranged according to viewing priority; 

0) ascertaining whether an active overlying graphic object overlaps an 
underlying graphic object within an overlap region; 

(m) where such an overlap occurs, performing clipping operations using the 
boundaries of the overlying graphic object and the underlying graphic object to generate 
clipped versions of the overlying and/or underlying graphic objects within the overlap 
region and/or clipped versions of the underlying and/or overlying graphic objects outside 
the overlap region; 
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(n) adding to the level activation table; 

(na) one or more Erst levels corresponding to those regions of the 
underlying and overlying graphic objects disposed within the overlap region; and/or 

(nb) one or more second levels corresponding to those regions of the 
underlying and/or overlying graphic objects disposed outside the overlap region; and 

(o) for each pixel within said image, determining a compositing stack based on 
the level activation table entries relevant to that pixel location. 

69. A method according to claim 68, wherein step (j) comprises a sub-step (ja) of 
determining, in a predetermined order, coordinates of intersection of those edges of said 
objects that intersect said current scan line. 

70. A method according to claim 68, wherein: 

step (1) comprises a substep (la) of determining a compositing operator which 
applies to the overlapping graphic objects; and 

step (m) comprises a substep (ma) of performing the clipping operations using the 
edges of the overlying object and/or the underlying object on the basis of the compositing 
operator determined in substep (ia). 

71. A method according to claim 70, wherein substep (rib) comprises a substep (nc) of 
adding to the level activation table the one or more second levels corresponding to the 
underlying and/or overlying objects, the one or more second levels being selected for 
addition to the level activation table on the basis of the compositing operator determined 
in substep (la). 

72. A method according to claim 69, wherein said compositing operator is a Porter 
and Duff compositing operator. 
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73. A method according to claim 1 or 12, said processing comprising a sixth process 
for generating a compositing stack based on table entries in a level activation table, for 
use in rendering said plurality of graphic objects onto said raster pixel image having a 
plurality of scan lines and a plurality of locations on each scan line, each of the graphic 
objects being described by components comprising at least an edge and a viewing priority 
relative to the other graphic objects, the sixth process including the steps of: 

(j) determining, in a predetermined order, coordinates of intersection of those 
edges of said objects that intersect said scan line; 

(k) for each edge intersection so determined, updating the level activation table, 
the level activation table being arranged according to viewing priority; 

(1) ascertaining whether an active . overlying graphic object overlaps an 
underlying graphic object within an overlap region; 

(m) where such an overlap occurs, performing clipping operations using edges of 
the overlying graphic object and the underlying graphic object to generate clipped 
versions of the overlying and/or underlying graphic objects within the overlap region 
and/or clipped versions, of the underlying and/or overlying graphic objects outside the 
overlap region; 

(n) adding to the level activation table: 

(na) one or more first levels corresponding to those regions of the 
underlying and overlying graphic objects disposed within the overlap region; and/or 

(no) one or more second levels corresponding to those regions of the 
underlying and/or overlying graphic objects disposed outside the overlap region; and 

(o) for each pixel location on the scan line, determining a compositing stack 
based on the level activation table entries relevant to that pixel location. 

74. A method according to claim 73, wherein step (m) comprises the sub-step of 
performing clipping operations using edges of the overlying graphic object and the 
underlying graphic object to generate clipped versions of the overlying and underlying 
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graphic objects within the overlap region and a clipped version of the underlying or 
overlying graphic objects outside the overlap region. 

75. A method according to claim 68, wherein said overlying object is non-opaque. 

3. Detailed Explanation of the Invention 

[Field of Invention] 

The present invention relates to the rendering of object graphic elements into 
raster pixel images and, in particular, to efficient rendering of such elements to pixel 
image data without the use of frame or line storage of the pixel data as part of the 
rendering process. 

[Background of Invention] 
Most object based graphics systems utjlise a frame store or page buffer to hold a 
pixel-based image of the page or screen. Typically, the outlines of the graphic objects are 
calculated, filled and written into the frame store. For two-dimensional graphics, objects 
which appear in front of other objects are simply written into the frame store after the 
background objects, thereby replacing the background on a pixel-by-pixel basis. This is 
commonly known in the art as the "Painter's algorithm". Objects are considered in 
priority order, from the rearmost object to the foremost object, and, typically, each object 
is rasterised in scan line order and pixels arc written to the frame store in sequential runs 
along each scan line. 

There are essentially two problems with this technique. The first is thai it requires 
fast random access to all the pixels in the frame store. This is because each new object 
considered could affect any pixel in the frame-store. For this reason, the frame store is 
normally kept in semiconductor random access memory (RAM). For high resolution 
colour printers the amount of RAM required is very large, typically in excess of 
lfJO MBytes, which is costly and difficult to operate at high speed. The second problem 
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is that many pixels which are painted (rendered), are over-painted (re-rendered) by later 
objects. Painting the pixels with the earlier objects was a waste of time. 

One method for overcoming the large frame-store problem is the use of "banding". 
When banding is used, only part of the frame-store exists in memory at any one time. All 
of the objects to be drawn are retained in a "display list". The whole image is rendered as 
above, but pixel painting (rendering) operations that try to paint (render) outside the 
fraction of the frame-store which exists are "clipped" out. After all the objects have been 
drawn, the fractional part of the frame-store is sent to the printer (or some other location) 
and another fraction of the frame-store is selected and the process repeated. There are 
penalties with this technique. For example, the objects being drawn must be considered 
and re-considered many times - once for each band. As the number of bands increases, so 
too does the repetitious examination of objects requiring rendering. The technique of 
banding does not solve the problem of the cost of over-painting. 

Some other graphic systems consider the image in scan line order. Again, all the 
objects to be drawn are retained in a display list. On each scan line the objects which 
intersect that scan line are then considered in priority order and for each object, spans of 
pixels between object edge intersection points are set in a line store. This technique aiso 
overcomes the large frame store problem, but still suffers from the over-paint problem. 

There are other techniques which overcome both the large frame-store problem 
and the over-painting problem. In one such technique, each scan line is produced in turn. 
Again; all the objects to be drawn are retained in a display list. On each scan line, the 
edges of objects which intersect that scan line are held in order of increasing coordinate of 
intersection with the scan line. These points of intersection, or edge crossings, are 
considered in turn and used to toggle an array of active flags. There is one active flag for 
each object priority which is of interest on the scan line. Between each pair of edges 
considered, the colour date for each pixel which lies between the first edge and the next 
edge is generated by using a priority encoder on the active flags to determine which 
priority is topmost, and using the colour associated with that priority for ihe pixels of the 
span between the two edges. In preparation for the next scan line, the coordinate of 
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intersection of each edge is updated in accordance with the nature of each edge. Adjacent 
edge? which become mis-sorted as a result of this update arc swapped. New edges are 
also merged into the list of edges. 

This technique has the significant advantages that there is no frame store or line 
store, there is no over painting, and the object priorities are dealt with in constant order 
time, rather than order N time (where N is the number of priorities). 

However, there are several limitations to this technique: 

(i) The technique only supports .the "odd-even" fill rule, known in the art for 
determining the inside versus outside state of an object from its edges. The "non- 
zero winding" fill rule, which is a required feature of many graphic description 
languages, is not supported by that technique. 

(ii) Large mis-sorting can occur for which a simple swapping technique is 
inadequate to repair. While a brute-force sort of the whole of the edge list on each 
scan line can be performed, this is very slow. 

(in) The technique does not support raster (pixel-based) images as an object type. 
Such images are a required feature of most graphic description languages. 

(iv) The technique only supports objects which are opaque, where each painted 
pixel strictly obscures the pixels of objects with lesser priority. The technique does 
not support raster operations in which the colour of two or more graphic objects 
interact. Such operations include drawing in XOR mode, or the compositing of 
partially transparent objects. These modification operations are a required feature 
of most graphic description languages. 

(v) The technique does not support clipping, where one or more clip shapes 
suppress some number of other graphics objects inside (or outside) the bounds of 
the clip shapes. Clipping is a required feature of most graphic description 
languages. 

(vi) The technique uses voluminous and inefficient encoding of object edges, 
particularly for text It is desirable for such an extremely common element of 
graphic descriptions to be represented in a simpler fashion. 
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(vii) The technique in some instances does not provide for accurate evaluation of 
complicated compositing expressions where the activity of one or more objections 
is variable. 

The inability of the technique to implement many features required by existing 
graphic description languages severely limits its use. 

Further, some existing rendering interfaces require implementation of the bit-wise 
logical combination of the colour of two or more graphic objects. Other existing 
rendering interfaces require implementation of an alpha channel (also referred to as 
transparency, opacity, or matte) based combination of the colour of two or more graphic 
objects. Current techniques do not allow these two features to be implemented in a 
unified fashion. 

[Summary of the Invention] 
It is an object of the present invention to substantially overcome, or at least 
ameliorate, one or more deficiencies with prior art sys terns. 

In accordance with one aspect of the present invention there is disclosed a 
method of processing graphic objects intended to form a raster pixel image, said 
processing comprising a process for determining an intersection order between edges of 
said graphic objects by evaluating corresponding edge records for a current scan line in 
rasterised display order and determining an edge intersection value for each said edge for 
a subsequent scan line, said process comprising, during processing of said edge records, 
the steps of: 

retaining a limited number of processed edge records in an unordered first buffer 
and progressively transferring said processed edge records to a second buffer in order, as 
orderable processed edge records are added to said first buffer, 

transferring unordcrable processed edge records lo a third buffer in order to order 
said edge records in said third buffer; and 

selectively processing edge records from said second and third buffers for 
determining ordered intersections for a subsequent scan line. 

In accordance with another aspect of the present invention there is disclosed a 
method of processing graphic objects intended to form a raster pixel image.in a graphic 
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object rendering system, said processing comprising a first process for determining an 
intersection order between edges of said graphic objects and a current scan line of said 
raster pixel image, said system comprising: 

plural edge records for each of a current scan line and a subsequent scan line, each 
of said records including a plurality of record locations for retaining at least a pixel 
location value of a corresponding edge on ihe corresponding scan line, each of said 
current and subsequent edge records being divided into at least a main portion and a spill 
portion, at least the main portion of said current edge records being arranged in raster 
pixel order; 

at least one current active edge record; 
a spill active edge record, and 

a pool including a limited predetermined number of edge records; 
said method comprising the steps of: 

(a) transferring a first edge record from each of said main and spill portions Of 
said current edge records into the corresponding active edge records; 

(b) comparing values of said active edge records to determine that said active 
edge record having a lowest value in said raster pixel order and outputting that value and 
record as a current edge value and record; 

(c) updating said current edge record with a value of Ihe corresponding edge for 
said subsequent scan line; 

'(d) comparing the updated edge value with edge values within said pool, 
wherein if the updated edge value is less than an edge value in said pool then 

(da) said updated current edge record is transferred to the spill portion of 
the subsequent edge records; otherwise 

(db) (dba) an edge record having a smallest edge value is transferred from 
said pool to a next record of the main portion of said subsequent edge record; and 

(dbb) said updated edge record is transferred to the record of said pool 
vacated in sub-step (dba); and 
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(dc) a further edge record is transferred from (he corresponding portion of 
the current edge record to the active edge record vacated by the updated edge record; 

(e) repeating steps (b) to (d) until each of said records in said pool are occupied 
whereupon a smallesl edge value record of said pool is transferred to said main portion of 
said subsequent edge records; 

(f) repeating steps (b) to (e) until all record? of said current records have been 
updated, and then flushing records from said pool in order to respective next records 
within said main portion of said subsequent records; 

(g) sorting said records in said spill portion of said subsequent records into 
raster pixel order; 

(h) transferring said subsequent edge records to said current edge records; and 

(i) repeating steps (a) to (h) for each further scan line of said raster pixel image. 
In accordance with another aspect of the present invention there is disclosed 

apparatus for processing graphic objects Intended to form a raster pixel image, said 
processing comprising a process for determining an intersection order between edges of 
said graphic objects by evaluating corresponding edge Tecords for a current scanline in 
rastcrised display order and determining an edge intersection value for eacb said edge for 
a subsequent scanline, said apparatus comprising: 

a memory having an unordered first bnffcr, a second buffer and a third buffer; 

and 

a processor for retaining a limited number of processed edge records in said 
unordered first buffer, for progressively transferring said processed edge records to said 
second buffer in order, as orderable processed edge records are added to said first buffer, 
for transferring unorderable processed edge records to said third buffer in order to order 
said edge records in said tbird buffer, and for selectively processing edge records from 
said second and third buffers for determining ordered intersections for a subsequent 
scanline. 

In accordance with another aspect of the present invention there is disclosed 
apparatus for processing graphic objects intended to form a raster pixel image, said 
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processing comprising a process for determining an intersection order between edges of 
said graphic objects by evaluating corresponding edge records for a current scan line in 
rasterised display order and determining an edge intersection value for each said edge for 
a subsequent scan line, said apparatus comprising: 

means for retaining a limited number of processed edge records in an unordered 
first buffer and progressively transferring said processed edge records to a second buffer 
in order, as otderable processed edge records are added to said first buffer; 

means for transferring unorderable processed edge records to a third buffer in 
order to order said edge records in said third buffer; and 

means for selectively processing edge records from said second and third buffers 
for determining ordered intersections for a subsequent scan line. 

In accordance with another aspect of the present invention there is disclosed a 
computer readable memory medium for storing a program for apparatus which processes 
graphic objects intended to form a raster pixel image, said processing comprising a 
process for determining an intersection order between edges of said graphic objects by 
evaluating corresponding edge records for a current scan line in rasterised display order 
and detcrrnining an edge intersection value for each said edge for a subsequent scan line, 
said program comprising: 

code for a retaining step for retaining a 1 imited number of processed edge records 
in an unordered first buffer and progressively transferring said processed edge records to 
a second buffer in order, as orderable processed edge records are added to said first 
buffer; 

code for a transfer step for transferring unorderable processed edge records to a 
third buffer in order to order said edge records in said third buffer; and 

code for a process step for selectively processing edge records from said second 
and third buffers for determining ordered intersections for a subsequent scan line. 

Other aspects of the present invention will be apparent from the following 
description. 
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[Embodiments] 

Fig. 1 illustrates schematically a computer system 1 configured for rendering and 
presentation of computer graphic object images. The system includes a host processor 2 
associated with system random access memory (RAM) 3, which may include a non- 
volatile bard disk drive or similar device 5 and volatile, semiconductor RAM 4. The 
system 1 also includes a system read-only memory (ROM) 6 typically founded upon 
semiconductor ROM 7 and which in many cases may be supplemented by compact disk 
devices (CD ROM) 8. The system 1 may also incorporate some means 10 for displaying 
images, such as a video display unit (VDU) or a printer, both of which operate in raster 
fashion. 

The above-described components of the system 1 are interconnected via a bus 
system 9 and are operable in a normal operating mode of computer systems well known 
in the art,, such as IBM PC/AT type personal computers and arrangements evolved 
therefrom, Sun Sparcstations and the like. 

Also seen in Fig. 1, a pixel sequential rendering apparatus 20 connects to the 
bus 9, and in the preferred embodiment is configured for the sequential rendering of 
pixel-based images derived from graphic objecl-based descriptions supplied with 
instructions and data from the system 1 via the bus 9. The apparatus 20 may utilise the 
system RAM 3 for the rendering of object descriptions although preferably the rendering 
apparatus 20 may have associated therewith a dedicated rendering store arrangement 30, 
typically formed of semiconductor RAM. 

Refeiring now to Fig. 2, a functional data flow diagram of the preferred 
embodiment is shown. The functional flow diagram of Fig. 2 commences with an object 
graphic description 11 which is used to describe those parameters of graphic objects in a 
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fashion appropriate to be generated by the host processor 2 and/or, where appropriate, 
stored within the system RAM 3 or derived from the system ROM 6, and which may be 
interpreted by the pixel sequential rendering apparatus 20 to render therefrom pixel-based 
images. For example, the object graphic description 1 1 may incorporate objects with 
edges in a number of formats including straight edges (simple vectors) that traverse from 
one point on the display to another, or an orthogonal edge format where a two- 
dimensional object Is defined by a plurality of edges including orthogonal lines. Further 
formats, where objects are defined by continuous curves, are also appropriate and these 
can include quadratic polynomial fragments where a single curve may be described by a 
number of parameters which enable a quadratic based curve to be rendered in a single 
output space without the need to perform multiplications. Further data formats, such as 
cubic splines and the like may also be used. An object may contain a mixture of many 
different edge types. Typically, common to all formats are identifiers for the start and end 
of each line (whether straight or curved) and typically, these are identified by a scan line 
number thus defining a specific output space in which the curve may be rendered. 

For example, Fig. 16A shows a prior art edge description of an edge 600 that is 
required to be divided into two segments 601 and 602 in order for the segments to be 
adequately described and rendered. This arises because the prior art edge description, 
whilst being simply calculated through a quadratic expression, could not accommodate an 
inflexion point 604. Thus the edge 600 was dealt with as two separate edges having end 
points" 603 and 604, and 604 and 605 respectively. Fig. 16B shows a cubic spline 610 
which is described by end points 611 and 612, and control points 613 and 614. This 
format requires calculation of a cubic polynomial for render purposes and thus is 
expensive of computational time. 

Figs. 16C and 16D show examples of edges applicable to the preferred 
embodiment. In the preferred embodiment, a edge is considered as a single entity and if 
necessary, is partitioned to delineate sections of the edge that may be described in 
different formats, a specific goal of which is to ensure a minimum level of complexity for 
the description of each section. 
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In Fig. 16C, a single edge 620 is illustrated spanning between scan lines A and M. 
An edge i'b described by a number of parameters including start_x , start_y , one or more 
segment descriptions which include an address that points to the next segment in the edge, 
and a finish segment used to terminate the edge. According to the preferred embodiment, 
the edge 620 may be described as having three step segments, a vector segment, and a 
quadratic segment. A step segment is simply defined as having an x-step value and a y- 
step value. For the three step segments illustrated, the segment descriptions are [0,2], 
[+2,2], and [+2,0]. Note that the x-step value is signed thereby indicating the direction of 
the step, whilst the y-step value is unsigned as such is always m a raster scan direction of 
increasing scan line value. The next segment is a vector segment which typically requires 
parameters startjc, start_y, finish_y and slope (DX). In this example, because the vector 
segment is an intermediate segment of the edge 620, the start_x and start_y may be 
omitted because such arise from the preceding segments). The slope value (DX) is 
signed and is added to the x-value of a preceding scan line to give the x-value of the 
current scan line, and in the illustrated case, DX = +1. The next segment is a quadratic 
segment; which has a structure corresponding to that of the vector segment, but also a 
second order value (DDX) which is also signed and is added to DX to alter the slope of 
the segment. 

Fig. 16D shows an example of a cubic curve according the preferred embodiment 
which includes a description corresponding to the quadratic segment save for the addition 
of a signed third-order value (DDDX), which is added to DDX to vary the rate of change 
of slope of the segment Many other orders may also be implemented. 

It will be apparent from the above that the ability to handle plural data formats 
describing edge segments allows for simplification of edge descriptions and evaluation, 
without reliance oa complex and computationally expensive mathematical operations. In 
contrast, in the prior art system of Fig. 16A, all edges, whether, orthogonal, vector or 
quadratic were required to be described by the quadratic form. 

The operation of the preferred embodiment will be described with reference to the 
simple example of rendering an image 78 shown in Fig. 8. The image 78 is seen to 
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include two graphical objects, in particular, a partly transparent blue-coloured triangle 80 
rendered on top of and thereby partly obscuring an opaque red coloured rectangle 90. As 
seen, the rectangle 90 includes side edges 92, 94, 96 and 98 defined between various pixel 
positions (X) and scan line positions (Y). Because the edges 96 and 98 are formed upon 
the scan lines (and thus parallel therewith), the actual object description of the 
rectangle 90 can be based solely upon the side edges 92 and 94, such as seen in Fig. 9A. 
In this connection, edge 92 commences at pixel location (40,35) and extends in a raster 
direction down the screen to terminate at pixel position (40,105). Similarly, the edge 94 
extends from pixel position (160,35) to position (160,105). The horizontal portions of the 
rectangular, graphic object 90 may be obtained merely by scanning from the edge 92 to 
the edge 94 in a rasterised fashion. 

The blue triangular object 80 however is defined by three object edges 82, 84 
and 86, each seen as vectors that define the vertices of the triangle. Edges 82 and 84 are 
seen to commence at pixel location (100,20) and extend respectively to pixel locations 
(170,90) and (30,90). Edge 86 extends between those two pixel locations in a traditional 
rasterised direction of left to right. In this specific example because the edge 86 is 
horizontal like the edges 96 and 98 mentioned above, is it not essential that the edge 86 be 
defined, since the edge 86 is characterised by the related endpoints of the edges 82 
and 84. In addition to the starting and ending pixel locations used to describe the 
edges 82 and 84, each of these edges will have associated therewith the slope value in thjs 
case +1 and -1 respectively. 

Fig. 10 shows the manner in which the rectangle 90 is rendered, this commencing 
on scan line 35 and how the edges 82 and 84 intersect the scan line 35. It will be apparent 
from Fig. 10 that the rasterisation of the image 78 requires resolution of the two 
objects 90 and 80 in such a fashion that the object having the higher priority level is 
rendered "above" that with a lower priority level. This is seen from Fig. 11 which 
represents an edge list record used for the rendering of the image 78. The record of 
Fig. 11 includes two entries, one for each of the objects, and which are arranged at a scan 
line value corresponding to the start, in a raster rendering order, of the respective object. 
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It will be seen from Fig. 11 that the edge records each have an.associatcd priority level of 
the object and further detail regarding the nature of the edge being described (eg. colour, 
, slope, etc.) 

Returning to Fig. 2, having identified (he data necessary to describe the graphic 
objects to the rendered, the graphic systems 1 then performs a display list generation 
step 12. 

The display list generation 12 is preferably implemented as a software module 
executing on the host processor 2 with attached ROM 6 and RAM 3. The display list 
generation 12 converts an object graphics description, expressed in any one or more of the 
well known graphic description languages, graphic library calls, or any other application 
Specific format, into a display list. The display list is typically written into a display list 
store 13, generally formed within the RAM 4 but which may alternatively be formed 
within the rendering stores 30. As seen in Fig. 3, the display list store 13 can include a 
number of components, one being an instruction stream 14, another being edge 
information 15 and where appropriate, raster image pixel data 16. 

The instruction stream 14 includes code interpretable as instructions to be read by 
the pixel sequential rendering apparatus 20 to render the specific graphic objects desired 
in any specific image. For the example of the image shown in Fig. 8, the instruction 
stream 14 could be of the form of: 

(1) render (nothing) to scan line 20; 

(2) at scan line 20 add two blue edges 82 and 84; 

(3) render to scan line 35; 

(4) at scan line 35 add two red edges 92 and 94; 

(5) reader to completion. 

Similarly, the edge information 15 for the example of Fig. 8 may include the 
following: 

edge 84 commences at pixel position 100, edge 82 commences at pixel 
position 100; 
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edge 92 commences at pixel position 40, edge 94 commences at pixel 
position 160; 

edge 84 runs for 70 scan lines, edge 82 runs for 70 scan lines; 

edge 84 has slope = -1, edge 84 has slope = +1; 

edge 92 has slope = 0 edge 94 has slope = 0; and 

edges 92 and 94 each run for 70 scan lines. 
It will be appreciated from the above example oF the instruction stream 14 and 
edge information 15, and the manner in which each are expressed, that in the image 78 of 
Fig. 8, the pixel position (X) and the scan line value (Y) define a single output space in 
which the image 78 is rendered. Other output space configurations however can be 
realised using the principles of the present disclosure. 

Fig. 8 includes no raster image pixel data and hence none need be stored in the 
store portion 16 of the display list 13, although this feature will be described later. 

The display list store 13 is read by a pixel sequential rendering apparatus 20, 
which is typically implemented as an integrated circuit. The pixel sequential rendering 
apparatus 20 converts the display list into a stream of raster pixels which can be 
forwarded to another device, for example, a printer, a display, or a memory store. 

Although the preferred embodiment describes the pixel sequential rendering 
apparatus 20 as an integrated circuit, it may be implemented as an equivalent software 
module executable on a general purpose processing unit, such as the host processor 2. 
The software module may form part of a computer program product which may be 
delivered to a user via a computer readable medium, such as a disk device or computer 
network. 

Fig. 3 shows the configuration of the pixel sequential rendering apparatus 20, the 
display list store 13 and the temporary rendering stores 30. The processing stages 22 of 
the pixel-sequential render apparatus 20 include an instruction executor 300, an edge 
processing module 400, a priority determination module 500, a fill colour determination 
modulo 600, a pixel compositing module 7O0, and a pixel output module 800. The 
processing operations use the temporary stores 30 which as noted above, may share the 
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same device (eg. magnetic disk or semiconductor RAM) as the display list store 13, or 
may be implemented as individual stores for reasons of speed optimisation. The edge 
processing module 400 uses an edge record store 32 to hold edge information which is 
carried forward from scan-line to scan-line. The priority determination module 500 uses 
a priority properties and status table 34 to hold information about each priority, and the 
current state of each priority with respect to edge crossings while a scan-line is being 
rendered. The fill colour determination module 600 uses a fill data table 36 to hold 
information required to determine the fill colour of a particular priority at a particular 
position. The pixel compositing module 700 uses a pixel compositing stack 38 to hold 
intermediate results during the determination of an output pixel that requires the colours 
from multiple priorities to determine its value. 

The display list store 13 and the other stores 32-38 detailed above may be 
implemented in RAM or any other data storage technology. 

The processing steps shown in the embodiment of Fig. 3 take the form of a 
processing pipeline 22. In this case, the modules of the pipeline may execute 
simultaneously on different portions of image data in parallel, with messages passed 
between them as described below. In another embodiment, each message described 
below may take the form of a synchronous transfer of control to a downstream module, 
with upstream processing suspended until the downstream module completes the 
processing of the message. 

' The instruction executor 300 reads and processes instructions from the instruction 
stream 14 and formats the instructions into messages that transferred via an output 398 to 
the other modules 400, 500, 600 and 700 within the pipeline 22. hj the preferred 
embodiment, the instruction stream 14 may include the instructions: 

LOAD_PRIORITY_PROPERTIES: This instruction is associated with data to be 
loaded into the priority properties and status table 34, and ah address in that table to 
which the data is to be loaded. When this instruction is encountered by the instruction 
executor 300, the instruction executor 300 issues a message for the storage of the data in 
the . specified location of the priority properties and status table 34. This may be 
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accomplished by fonnatting a message containing this data and passing it down the 
processing pipeline 22 to the priority determination module 500 which performs the store 
operation. 

LOAD_FILL_DATA: This instruction is associated with data to be loaded into the 
fill data table 36, and an address in that table to which the data is to be loaded. When this 
instruction is encountered by the instruction executor 300, the instruction executor 300 
issues a message for the storage of the data at the specified address of the fill data 
table 36. This may be accomplished by formatting a message containing this data and 
passing it down the processing pipeline 22 to the All data determination module which 
performs the store operation. 

LOAD_NEW_EDGES_AND_RENDER: This instruction is associated with an 
address in the display list store 13 of new edges 15 which are to be introduced into the 
rendering process when a next scan line is rendered. When this instruction is encountered 
by the instruction executor, the instruction executor 300 formats a message containing 
this data and passes it to the edge processing module 400. The edge processing 
module 400 stores the address of the new edges in the edge record store 32. The edges at 
the specified address are sorted on their initial scan line intersection coordinate before the 
next scan line is rendered, [n one embodiment, the edges an sorted by the display list 
generation process 12. In another embodiment, the edges are sorted by the pixel- 
sequential rendering apparatus 20. 

"SET_SCAN LINE_LENGTH: This instruction is associated with a number of 
pixels which ate to be produced in each rendered scan line. When this instruction is 
encountered by the instruction executor 300, the instruction executor 300 passes the value 
to the edge processing module 400 and the pixel compositing module 700. 

SET_OPACFTY_MODE: This instruction is associated with a flag which 
indicates whether pixel compositing operations will use an opacity channel (also known 
in the art as an alpha channel). When this instruction is encountered by the Instruction 
executor 300, the instruction executor 300 passes the flag value in the pixel compositing 
module 700. 
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The instruction executor 300 is typically formed by a microcode state machine 
which maps instructions and decodes them into pipeline operations for passing to the 
various modules. A corresponding software process may alternatively be used. 

The operation of the edge processing module 400 during a scan line render 
operation will now be described with reference to Fig. 4. The initial conditions for the 
rendering of a scan line is the availability of three lists of edge records. Any or all of 
these lists may be empty. These lists are a new edge list 402, obtained from the edge 
information 15 and which contains new edges as set by the 
LOAD_NEW_EDGES_AND_RENDER instruction, a main edge list 404 which contains 
edge records carried forward from the previous scan line, and a spill edge list 406 which 
also contains edge records carried forward from the previous scan line. Bach edge record 
may include: 

(i) a current scan line intersection coordinate (referred to here as the X 
coordinate), 

(ii) a count (referred to herein as NY) of how many scan lines a current segment 
of this edge will last for (in some embodiments this may be represented as a Y 
limit), 

(Iii)a value to be added to the X coordinate of this edge record after each scan line 

(referred to here as the DX), 
(iv)a value to be added to the DX of this edge record after each scan line (referred 

to here as the DDX), 
'• (v) one or more priority numbers (P), 

(vi) a direction (DIR) flag which indicates whether the edge crosses scan lines in 
an upward (+) or a downward (-) manner, and 

(vii) an address (ADD) of a next edge segment in the list. 

Such a format accommodates vectors, orthogonally arranged edges and quadratic 
curves. The addition of further parameters, DDDX for example, may allow such an 
arrangement to accommodate cubic curves. In some applications, such as cubic Bezier 
spline, a 6-order polynomial (ic: up to DDDDDDX) may be required. 
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For the example of the edges 84 and 94 of Fig. 8, the corresponding edge records 
at scan line 20 could read as follows in Table 1: 

TABLE 1 



Edge 84 


Edge 92 


X =100 


X =40 


NY =70 


NY =70 


DX '= 1 


DX = 0 


DDX = 0 


DDX = 0 


P - 1 


P =0 


DIR = (-) 


DIR = (+) 


ADD = (irrelevant in.tfais example) 


ADD = (irrelevant in this example) 



In this description, coordinates which step from pixel to pixel along a scan line 
being generated by the rendering process will be referred to as X coordinates, and 
coordinates which step from scan line to scan line will be referred to as Y coordinates. 
Preferably, each edge list contains zero or more records placed contiguously in memory. 
Other storage arrangements, including the use of pointer chains, are also possible. The 
records in each of the three lists 402, 404 and 406 are arranged in order of scan line 
intersection (X) coordinate. This is typically obtained by a sotting process, initially 
managed by an edge input module 408 which receives messages, including edge 
information, from the instruction executor 300. It is possible to relax the sort to only 
regard the integral portion of each scan line intersection coordinate as significant. It is 
also possible to relax the sort further by only regarding each scan line intersection 
coordinate, clamped to the minimum and maximum X coordinates which are being 
produced by the current rendering process. Where appropriate, the edge input 
module 408 relays messages to modules 500, 600 and 700 downstream in the pipeline 22 
via an output 498, 

The edge input module 408 maintains references into and receives edge data from 
each of the three lists 402, 404, and 406. Each of these references is initialised to refer to 
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the first edge in each list at the start of processing of a scan line. Thereafter, the edge 
input module 408 selects an edge record from one of the three referenced edge records 
such that the record selected is the one with the least X coordinate out of the three 
referenced records. If two or more of the X-records are equal each are processed in any 
order and the corresponding edge crossings output in the following fashion. The 
reference which was used to select that record is then advanced to the next record in that 
list. The edge just selected is formatted into a message and sent to an edge update 
module 410. Also, certain fields of the edge, in particular the current X, the priority 
numbers, and the direction flag, are formatted into a message which is forwarded to the 
priority determination module 500 as an output 498 of the edge processing module 400. 
Embodiments which use more or fewer lists than those described here are also possible. 

Upon receipt of an edge, the edge update module 410 decrements the count of how 
many scan lines for which a current segment will last. If that count has reached zero, a 
new segment is read from the address indicated by the next segment address. A segment 
specifies: 

(i) a value to add to the current X coordinate immediately the segment is read, 

(ii) a new DX value for the edge, 

(iii) a new DDX value for the edge, and 

(Iv)a new count of how many scan lines for which the new segment will last, 
If there is no next segment available at the indicated address, no further processing 
is performed on that edge. Otherwise, the edge update module 410 calculates the X 
coordinate for the next scan line for the edge. This typically would involve taking the 
current X coordinate and adding to it the DX value. The DX may have the DDX value 
added to it, as appropriate for the type of edge being handled. The edge is then written 
into any available free slot in an edge pool 412, which is an array of two or more edge 
records. If there is no free slot, the edge update module 410 waits for a slot to become 
available. Once the edge record is written into the edge pool 412, the edge update 
module 410 signals via a line 416 to an edge output module 414 that a new edge has been 
added to the edge pool 412. 
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As an initial condition for the rendering of a scan line, the edge output module 414 
has references to each of a next main edge list 420 and a next spill edge list 422, not seen 
in Fig. 4 but associated with the lists 404 and 406 in the edge record 32. Each of these 
references is initialised to the location where the, initially empty, lists 420 and 422 may 
be built up. Upon receipt of the signal 416 indicating that an edge has been added to the 
edge pool 412, the edge output module 414 determines whether or not the edge just added 
has a lesser X coordinate than the edge last written to the next main edge list 420 (if any). 
If this is true, a "spill" is said to have occurred because the edge cannot be appended to 
the main edge list 404 without violating its ordering criteria. When a spill occurs, the 
edge is inserted into the next spill edge list 422, preferably in a manner that maintains a 
sorted next spill edge list 422. For example this may be achieve using a software sorting 
routine. In some embodiments spills may be triggered by other conditions, such as- 
excessively large X coordinates. 

If the edge added to the edge pool 412 has an X coordinate greater than or equal to 
the edge last written to the next main edge list 420 (if any), and there are no free slots 
available in the edge pool 412, the edge output module 414 selects the edge from the edge 
pool 412 which has the least X coordinate, and appends that edge to the next main edge 
list 420, extending it in the process. The slot in the edge pool 412 which was occupied by 
that edge is then marked as free. 

Once the edge input module 408 has read and forwarded all edges from all three of 
its input lists 402, 404 and 406, it formats a message which indicates that the end of scan 
line has been reached and sends the message to both the priority determination module 
500 and the edge update module 410. Upon receipt of that message, the edge update 
module 410 waits for any processing it is currently performing to complete, then forwards 
the message to the edge output module 414. Upon receipt of the message, the edge output 
module 414 writes all remaining edge records from the edge pool 412 to the next main 
edge list 404 in X order. Then, the reference to the next main edge list 420 and Ihe main 
edge list 404 are exchanged between the edge input module 408 and the edge output 
module 414, and a similar exchange is performed for the next spill edge list 422 and the 
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spill edge list 406. In this way the initial conditions for the following scan linecare 
established 

Rather than sorting the next spill edge list 422 upon insertion of edge records 
thereto, such edge records may be merely appended to the list 422, and the list 422 sorted 
at the end of the scan line and before the exchange to the current spill list 406 becomes 
active in edge rasterisation of the next scan line. Other methods of sorting the edges 
involving fewer or more lists may be used, as well as different sorting algorithms. 

It can be deduced from the above that edge crossing messages are sent to the 
priority determination module 500 in scan line and pixel order (that is, they are ordered 
firstly on Y and then on X) and that each edge crossing message is labelled'with the 
priority to which it applies. 

Fig. 12A depicts a specific structure of an active edge record 418 that may be 
created by the edge processing module 400 when a segment of an edge is received. If the 
first segment of the edge is a step (orthogonal) segment, the X-value of the edge is added 
to a variable called "X-step" for the first segment to obtain the X position of the activated 
edge. Otherwise, the X-value of the edge is used. This means that the edges in the new 
edge record must be sorted by X^ge + X^p. The X,,^ of the first segment should, 
therefore, be zero, in order (a simplify sorting the edges. The Y-value of the first segment 
is loaded into the NY field of the active edge record 418. The DX field of the active 
edges copied from the DX field identifier of vector or quadratic segments, and is set to 
zero for a step segment. A u-flag as seen in Fig. 12A is se! if the segment is upwards 
heading (see the description relating to Fig. 13 A). A q-flag is set if the segment is a 
quadratic segment, and cleared otherwise. An i-flag is provided and is set if the segment 
is invisible. A d-flag is set when the edge is used as a direct cupping object, without an 
associated clipping level, and is applicable to closed curves. The actual priority level of 
the segment, or a level address is copied from the corresponding field of the new edge 
record into a level (ADDR) field in the active edge record 418. A segment address/DDX 
field of the active edge record 418 is either the address of the next segment in the segment 
list or copied from the segment's DDX value, if the segment is quadratic The segment 
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address is used to terminate an edge record. As a consequence, in the preferred 
embodiment, any quadratic curve (ie: that uses the DDX filed) will be a terminal segment 
of an edge record 

It will be appreciated from Fig. 12A that other data structures are also possible, 
and necessary for example where higher-order polynomial implementations are used. 
Further, the segment address and the DDX field may be separated into different fields, 
and additional flags provided to meet alternate implementations. 

Fig. 12B depicts the arrangement of the edge records described above in the 
preferred embodiment and used in the edge processing module 400. The edge pool 412 is 
supplemented by a new active edge record 428, a current active edge record 430 and a 
spill active edge record 43Z As seen in Fig. 12B, the records 402, 404, 406, 420 and 422 
are dynamically variable in size depending upon (he number of edges being rendered at 
any one time. Bach record includes a limit value which, for the case of the new edge 
list 402, is determined by a SIZE value incorporated with the 
LOAD_BDGES_AND_RENDER instruction. When such an instruction is encountered, 
S12E is checked and if non-zero, the address of the new edge record is loaded and a limit 
value is calculated which determines a limiting size for the list 402. 

Although the preferred embodiments utilises arrays and associated pointers for the 
handling of edge records, other implementations, such as linked lists for example may be 
used. These other implementations may be hardware or software-based, or combinations 
thereof. 

The specific rendering of the image 78 shown in Fig. 8 will now be described with 
reference to scan lines 34, 35 and 36 shown in Fig. 10. In this example, the calculation of 
the new X co-ordinate for the next scan line is omitted for the purposes of clarity, with 
Figs. 12C to 121 illustrating the output edge crossing being derived from one of the 
registers 428, 430 and 432 of the edge pool 412 

Fig. 12C illustrates the stale of the lists noted above at the end of rendering scan 
line 34 (the top portion of the semi-Uansparent blue triangle 80). Note that in scan line 34 
there are no new edges and hence the list 402 is empty. Each of the main edge lists 404 
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and next main edge list 420 include only the edges 82 and 84. Each of the lists includes a 
corresponding pointer 434, 436, and 440 which, on completion of scan line 34, point to 
the next vacant record in the corresponding lis). Each list also includes a limit pointer 450, 
denoted by an asterisk (*) which is required to point to the end of the corresponding list, . 
If linked lists were used, such would not be required as linked lists include null pointer 
terminators that perform a corresponding function. 

As noted above, at the commencement of each scan line, the next main edge 
list 420 and the main edge list 404 are swapped and new edges are received into the new 
edge list 402. The remaining lists are cleared and each of the pointers set to the first 
member of each list. For the commencement of scan line 35, the arrangement then 
appears as seen in Fig. 12D. As is apparent from Fig. 12D, the records include four active 
edges which, from Fig. 10, are seen to correspond to the edges 92, 94, 84 and 82. 

Referring now to Fig. 12E, when rendering starts, the first segment of the new 
edge record 402 is loaded into an active edge record 428 and the first active edge records 
of the main edge list 404 and spill edge list 406 are copied to records 430 and 432 
respectively. In this example, the spill edge list 406 is empty and hence no loading lakes 
place. The X-positions of the edges within the records 428, 430 and 432 arc then 
compared and an edge crossing is emitted for the edge with the smallest X-position. In 
this case, the emitted edge is that corresponding to the edge 92 which is output together 
with its priority value. The pointers 434, 436 and 438 are then updated to point to the 
next record in the list. 

The edge for which the edge crossing was emitted is then updated (in this case by 
adding DX = 0 to its position), and buffered to the edge pool 412 which, in this example, 
is sized to retain three edge records. The next entry in the list from which the emitted 
edge arose (in this case list 402) is loaded into the corresponding record (in this case 
record 428). This is seen in Fig. 12F. 

Further, as is apparent from Fig. 12F, a comparison between the registers 428, 430 
and 432 again selects the edge with tlie least X- value which is output as the appropriate 
next edge crossing (X=85, P=2). Again, the selected output edge is updated and added to 
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the edge pool 412 and all the appropriate pointers incremented. In this case, the updated 
value is given by X — X + DX, which is evaluated as 84 = 85 - 1. Also, as seen, the new 
edge pointer 434 is moved, in this case, to the end of the new edge list 402. 

In Fig. 12G, the next edge identified with the lowest current X-value is again that 
obtained from the register 430 which is output as an edge crossing (X=115, P=2). 
Updating of the edge again occurs with the value be added to the edge pool 412 as shown. 
At this time, it is seen that the edge pool 412 is now fuU and from which the edge with the 
smallest X-value is selected and emitted to the output list 420, and the corresponding 
limited pointer moved accordingly. 

As seen in Fig. 12H, the next lowest edge crossing is that from the register 428 
which is output (X=160 P=l). The edge pool 412 is again updated and the next small X- 
value emitted to the output list 420. 

At the end of scan line 35, and as seen in Fig. 121, the contents of the edge 
pool 412 are flushed to the output list 420 in order of smallest X-value. As seen in 
Fig. 12J, the next main edge list 420 and the main edge list 404 are swapped by 
exchanging their pointers in anticipation of rendering the next scan line 36. After the 
swapping, it is seen from Fig. 12J that the contents of the main edge list 404 include all 
edge current on scan line 36 arranged in order of X-position thereby permitting their 
convenient access which facilitates fast rendering. 

Ordinarily, new edges are received by the edge processing module 400 in order of 
increasing X-position. When a new edge arrives, its position is updated (calculated for 
the next scan line to be rendered) and this determines further action as follows: 

(a) if the updated position is less than the last X-position output on the line 498, 
the new edge is insertion sorted into the main spill list 406 and the corresponding limit 
register updated; 

(b) otherwise, if there is space, it is retained in the edge pool 412. 

As is apparent from the forgoing, the edge pool 412 aids in the updating of the 
lists in an ordered manner in anticipation of rendering the next scan line in the rasterised 
image. Further, the size of the edge pool 412 may be varied to accommodate larger 
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numbers of non-ordered edges. However, it will be appreciated that in practice the edge 
pool 412 will have a practical limit, generally dependent upon processing speed and 
available memory with the graphic processing system. In a limiting sense, the edge 
pool 412 may be omitted which would ordinarily require the updated edges to be insertion 
sorted into the next output edge list 420. However, in the preferred embodiment this 
situation is avoided, as a normal occurrence through the use of the spill lists mentioned 
above. The provision of the spill lists allows the preferred embodiment to be 
implemented with an edge pool of practical size and yet handle relatively complex edge 
intersections without having to resort to software intensive sorting procedures. In those 
small number of cases where the edge pool and spill list are together insufficient to 
accommodate the edge intersection complexity, sorting methods may be used. 

An example of where the spill list procedure is utilised is seen in Fig. 14A where 
three arbitrary edges 60, 61 and 63 intersect an arbitrary edge 62 at a relative position 
between scan lines A and B. Further, the actual displayed pixel locations 64 for each of 
scan lines A, B, are shown which span pixel locations C to J. In the above described 
example where the edge pool 412 is size to retain three edge records, it will be apparent 
that such an arrangement alone will not be sufficient to accommodate three edge 
intersections occurring between adjacent scan lines as illustrated in Fig. 14A. 

Fig. 14B shows the state of the edge records after rendering the edges 60, 61 
and 63 on scan line. The edge crossing H is that most recently emitted and the edge 
pool 412 is full with the updated X-valucs E, G and I for the edges 60, 61 and 63 
respectively for the next scan line, scan line B. The edge 62 is loaded into the current 
active edge record 430 and because the edge pool 412 is full, the lowest X-value, 
corresponding to the edge 60 is output to the output edge list 420. 

In Fig. 14C the next edge crossing is emitted (X = J for edge 62) and the 
corresponding updated value determined, in this case X = C for scan line B. Because the 
new updated value X = C is less than the most recent value X = E copied to the output 
list 420, the current edge record and its corresponding new updated value is transferred 
directly to the output spill list 422. 



(97) 



ft® 2000-149035 



Fig. 14D shows the state of the edge records at the start of scan line B where it is 
seen that the main and output lists, and their corresponding spill components have been 
swapped. To determine the first emitted edge, the edge 60 is loaded into the current 
active edge register 430 and the edge 62 is loaded into the spill active edge register 432. 
The X-values are compared and the edge 62 with the least Xrvalue (X = C) is emitted, 
updated and loaded to the edge pool 412. 

Edge emission and updating continues for the remaining edges in the main edge 
list 404 and at the end of the scan line, the edge pool 412 is flushed to reveal the situation 
shown in Kg, 14E, where it is seen that each of the edges 60 to 63 are appropriately 
ordered for rendering on the next scan line, having been correctly emitted and rendered on 
scan line B. . 

As will be apparent form the forgoing, the spill lists provide for maintaining edge 
rasterisation order in the presence of complex edge crossing situations. Further, by virtue 
of the lists being dynamically variable in size, large changes in edge intersection numbers 
and complexity may be handled without the need to resort to sorting procedures in all but 
exceptionally complex edge intersections. 

In the preferred embodiment the edge pool 412 is sized to retain eight edge 
records and size of the lists 404, 420 together with their associated spill lists 406, 422, is 
dynamically variable thereby providing sufficient scope for handling large images with 
complex edge crossing requirements. 

" The operation of the priority determination module 50 will now be described with 
reference to Fig. 5. Incoming messages 498 from the edge processing module 400, which 
may include set priority data messages, set fill data messages, edge crossing messages, 
and end of scan line messages, first pass through a first-in first-out (FIFO) buffer 518 
before being read by a priority update module 506. The FIFO 518 acts to de-couple the 
operation, of the edge processing module 400 and the priority determination module 500. 
A priority state tabic 502, comprising part of the tables 34 mentioned above, is used to 
hold information about each object priority. Preferably the FIFO 518 is sized to enable 
the receipt from the edge processing module 400 and transfer to the priority state 
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table 502 of a full scan line of edge-crossings in a single action. Such permits the priority 
determination module 500 to efficiently handle multiple edge-crossings at the same pixel 
(X) location. Each record in the priority state table 502 records: 

(i) a fiU-nile flag which indicates whether this priority is to have its inside versus 
. outside state determined by the application of the odd-cven fill rule or the non- 
zero winding fill rule; 

(ii) a fill count which is modified in a manner indicated by the fill rule each time a 
edge effecting this priority is crossed; 

(iii) a clipper flag which indicates whether this priority is to be used for Clipping or 
filling; 

(iv) a clip type flag which, for edges which have the clipper flag set, records 
whether the clipping type is a "clip-in" or a "clip-out"; 

(y) a clip count which is decremented and incremented when a clip-in type clip 
region effecting this priority is entered and exited respectively, and 
incremented and decremented when a clip-out type clip region effecting this 
priority is entered and exited respectively; and 
<vi)a flag which records whether this priority requires levels beneath it to be 

calculated first, referred to as the "need-below" flag. 
Clipping objects are known in the art and act not to display a particular new 
object, but rather to modify the shape of an another object in the image. Clipping objects 
can also be turned-on and tumed-off to achieve a variety of visual effects. For example, 
the object 80 of Fig. 8 could be configured as a clipping object acting upon the object 90 
to remove that portion of the object 90 that lies beneath the clipping object 80. This may 
have the effect of revealing any object or image beneath the object 90 and within the 
clipping boundaries that would otherwise be obscured by the opacity of the object 90. 

Figs. 13A arid 13B demonstrate the application of the odd-even and non-zero 
winding rules. For the purposes of the non-zero winding rule, Fig. 13A illustrates how 
the edges 71 and 72 of an object 70 are allocated a notional direction, according to 
whether the edges are downwards-heading or upwards-heading respectively. In order to 
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form a closed boundary, edges link nose-to-tail around the boundary. The direction given 
to an edge for the purposes of the fill-rule (applied and described later) Ls independent of 
the order in which the segments arc defined. Edge segments are defined in the order in 
which they arc tracked, corresponding to the rendering direction. 

Fig. 13B shows a single object (a pentagram) having two downwards-heading 
edges 73 and 76, and three upwards-heading edges 74, 75 and 77. The odd-even rule 
operates by simply toggling a Boolean value as each edge is crosses the scan line in 
question, thus effectively turning-on or tuming-off an object colour. The non-zero 
winding rule increments and decrements a fill count value dependent upon the direction 
of an edge being crossed. In Fig. 13B, the first two edges 73 and 76 encountered at the 
scan line are downwards-heading and thus traversal of those edge increment the fill count, 
to +1 and +2 respectively. The next two edges 74 and 77 encountered by the scan line are 
upwards-heading and accordingly decrement the fill count, to +1 and 0 respectively. 

In some embodiments some of this information is associated with edges in the 
display list 13 and various edge lists described above, and forwarded as part of the edge 
crossing message to the priority determination module 500. In particular, the fill-rule 
flag, the clipper flag, the clip type flag, and the nced-bclow flag may be handled in this 
manner. 

Returning to Fig. 5, the priority update module 506 maintains a counter 524 which 
records the scan line intersection coordinate up to which it has completed processing. 
This will be referred to as the current X of the priority update module 506. The initial 
value at the start of a scan line is zero. 

Upon examining an edge crossing message received at the bead of the FIFO 518, 
the priority update module 506 compares the X intersection value in the edge crossing 
message with its current X. If the X intersection value in the edge crossing message is 
less than or equal to the current X of the priority update module 506 processes the edge 
crossing message. Edge crossing message processing comes in two forms, "normal edge 
processing" (described below) is used when the record in the priority state table 502 
indicated by the first priority in the edge crossing message has a clipper flag which 
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indicates that this is not a clip priority, otherwise "clip edge processing" (described 
below) is performed. 

A priority is active at a pixel if the pixel is inside the boundary edges which apply 
to the priority, according to the fill-rule for that priority, and the clip count for the priority 
is zero. A priority is exposed if il is the uppermost active priority, or if all the active 
priorities above it have their corresponding need-below flags set. In this fashion, pixel 
values may generated using only the fill data of the exposed priorities. 

The need-below flag for a priority is established in the information of the display 
list and is used to inform the pixel generating system that any active priorities beneath the 
priority in question do not contribute to the pixel value being rendered, unless the flag is 
set. The flag is cleared where appropriate to prevent extra compositing operations which 
would otherwise contribute nothing to the final pixel value. 

"Normal edge processing" includes, for each priority in the edge crossing message 
and with reference to fields of the priority state table record indicated by that priority, the 
steps of: 

(i) noting the current fill count of the current priority; 

(ii) either 

(a) if the fill rule of the current priority is odd-even, setting the fill count 
to zero if it is currently non-zero, else setting it to any non-zero value, or 

(b) if the fill rule of the current priority Ls non-zero winding, incrementing 
or decrementing (depending on the edge direction flag) the fill count; and 

(iii) comparing the new fill count with the noted fill count and if one is zero and 
the other is non-zero performing an "active flag update" (described below) 
operation on the current priority. 

Same embodiments may use a separate edge crossing message for each priority 
rather than placing a plurality of priorities in each edge crossing message. 

An active flag update operation includes first establishing a new active flag for the 
current priority. The active flag is non-zero if the fill count for the priority in the priority 
Slate table 502 is non-zero and the clip count for the priority is zero, else the active flag is 
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zero. The second step in the active flag update operation is to store the determined active 
flag in an active flags array 508 at the position indicated by the current priority, then if the 
need-below flag in the priority state table for the current priority is zero, also storing the 
active flag in an opaque active flags array 510 at the position indicated by the current 
priority. 

"Clip edge processing" includes, with reference to fields of the priority state table 
record indicated by the first priority in the edge crossing message, the steps of: 
(i) noting the current fill count of the current priority, 
(11) either: 

(a) if the fill rule of the current priority is odd-even, setting the fill count 
to zero if it is currently non-zero else setting it to any non-zero value, or 

(b) if the fill rule of the current priority is non-zero winding, incrementing 
or decrementing (depending on the edge direction flag) the fill count; and 

(iii) comparing the new fill count with the noted fill count and determining a clip 
delta value of: , 

(a) zero, if both the new fill count is zero and the noted fill count is zero, 
or both the new fill count is non-zero and the noted fill count is non-zero, 

(b) plus one, if the clip type flag of the current priority is clip-out and the 
noted fill count is zero and the new fill count is non-zero, or the clip type flag 
of the current priority is clip-in and the noted fill count is non-zero and the 
new fill count is zero, or otherwise, 

(c) minus one; and 

(iv) for every subsequent priority after the first in the edge crossing message, add 
the determined clip delta value to the clip count in the record in the priority state 
stable indicated by that subsequent priority, and if the clip count either moved from 
non-zero to zero, or from zero to non-zero in that process, performing an active flag 
update operation as described above on, that subsequent priority. It should be noted 
that the initial value of each clip count is set by the LOAD_LEVEL_PROPERTIES 
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instruction described previously. The clip count is typically initialised to the 

number of clip-in priorities which affect each priority. 
Some embodiments do not associate a priority with a clip, but instead directly 
increment and decrement the clip count of all priorities given in the edge crossing 
message. This technique can be used, for example, when clip shapes are simple and do 
not require the application of a complex fill rule. In this specific application, the clip 
count of the level controlled by an edge is incremented for an upwards heading edge or 
decremented for a downwards heading edge. A simple closed curve, described 
anticlockwise, acts a clip-in, whereas a simple closed curve, described clockwise, acts as 
a clip-out. 

When the X intersection value in the edge crossing message is greater than the 
current X of the priority update module 506, the priority update module 506 forms a 
count of how many pixels to generate, being the difference between the X intersection 
value in the edge crossing message and the current X, this count is formatted into a 
priority generation message, which is sent via a connection 520 to a priority generation 
module 516. The priority update module 506 then waits for a signal 522 from the priority 
generation module 516 indicating that processing for the given number of pixels has 
completed. Upon receipt of the signal 522, the priority update module 506 sets its current 
X to the X intersection value in the edge crossing message and continues processing as 
described above. 

The priority generation module 516 operates with reference to a priority data 
table 504, also formed within the tables 34, which is used to hold Information about each 
priority. Each record in the priority data table 504 may include: 

(i) a fill table address, 

(ii) a fill type, 

(iii) a raster operation code, 

(iv) an alpha channel operation code, 

(v) a "source pop" flag, 

(vi) a "destination pop" Hag, and 
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(vii) a flag which records whether the colour of this priority is constant for a 
given Y, referred to here as the "x-independent" flag. 

Upon receipt of a priority generation message 520, the priority generation 
module 516 performs a "pixel priority generation operation" (described below) a number 
of times indicated by the count it has been supplied, thereupon it signals 522 the priority 
update module 506 that it has completed the operation. 

Each pixel priority generation operation includes firstly using a priority 
encoder 514 (eg. a 4096 to 12 bit priority encoder) on the opaque active flags array 510 to 
determine the priority number of the highest opaque active flag. This priority (if any) is 
used to index the priority data table 504 and the contents of the record so referenced is 
formed into a All priority message output 598 from the priority generation module 516 
and sent to the fill colour determination module 600. Further, if a priority was determined 
by the previous step (ie. there was at least one opaque active flag set), the determined 
priority is held, and is referred to as the "current priority". If no priority was determined 
the current priority is set to zero. The priority generation module 516 then repeatedly 
uses a modified priority encoder 512 on the active flag array 508 to determine the lowest 
active flag which is greater than the current priority. The priority so determined (if any) 
is used to' index the priority data table 504 and the contents of the record so referenced is 
formed into a fill priority message and is sent 598 to the fill colour determination 
module 500, then the determined priority is used to update the current priority. This step 
is used repeatedly until thereis no priority determined (that is, there is no priority flagged 
in the active flags which is greater than the current priority). Then the priority generation 
module 516 forms an end of pixel message and sends it to the fill colour determination 
module 600. 

As a preferred feature to the basic operation described above, the priority 
generation module 516 notes the value of the x-independent flag of each message which it 
forwards to the fill colour determination module 600 while it processes the first pixel of a 
sequence. If all the forwarded messages have the x-independent flag specified, all 
subsequent messages in the span of pixels between adjacent edge intersections can be 
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replaced by a single repeat specification of count minus one. This is done by producing a 
repeat message and sending it to the fill colour determination module 600 in place of all 
further processing in this sequence. 

As another preferred feature to the basic operation described above, the priority 
generation module 516 sends the highest opaque priority via (he connection 522 to the 
priority update module 506 after each level generation message. The priority update 
module 506 holds this in a store 526. The priority determination module 506 then, 
instead of a simple test that the X intersection in the message is greater than the current X, 
performs a test that the X intersection in the message is greater than the current X and that 
at least one of the levels in the message is greater than or equal to the highest opaque 
priority, before producing a pixel priority generation message. By doing this, fewer pixel 
priority determination operations may be performed and longer repeat sequences may be 
generated. 

Where the repeat message or sequence of operation is not utilized, as may be 
desired in some implementations, a similar function may be achieved through the 
incorporation of a cache or FIFO (not illustrated) at the output of the priority generation 
module 516, Such may be implemented by a four cell cache, for example. The cache 
allows the priority update module 506 continue working as soon as the cache is loaded, 
thereby permitting the generation of the next priority level independent of the flushing of 
the cache to the output 598. 

" Using the example of the graphic objects shown in Figs. 8 and 9, the priority 
update process described above can be illustrated, for scan line 35 using the edge 
crossings seen from Figs. 12C to 12J, as seen in Figs. 15A to 15E. 

Figs. ISA to 15E illustrate operation of the priority tables 502 and 504, which in 
the preferred embodiment ate merged for into a single table, called a level activation 
table 530, together with arrays 508, 510 and encoders 512 and 514. As seen in Fig. 15A, 
edge crossing messages are received in order for a scan line from the edge processing 
module 400 and are loaded into the table 530, which is arranged in priority order. The 
edge crossing messages include, in this example, an incrementing direction according to 



(105) 



»M 2000-149035 



the non-zero winging rule of the edge traversal. It is possible for no entries in the priority 
table 530 to be set. 

The level activation table as illustrated 530 includes column entries for fill count, 
which are determined from the edge according to the non-zero winding rule or, where 
appropriate, the odd-cvcn rule. The nced-bclow flag is a property af a priority and is set 
as part of the LOAD_PRIOR1TIES_PROPERTIES introduction. The need-below is set 
for all priority levels when the table 530 is loaded. Other columns such as "clip count" 
and "fill index table" may be used, but for this example are omitted for simplicity of 
explanation. "Where no level is active the corresponding entries are set to zero. Further, 
the values of the arrays 510 and 508 are updated from the table 530 after receiving a 
subsequent edge crossing. 

From Fig. ISA, it will be apparent that, for convenience, a number of records have 
been omitted for clarity. Typically, the level activation table 530 would include, arranged 
in priority order, the following records: 

fill count 

clip count 

fill type 

activation condition and flags, including 

(i) need - below flag 

(ii) clip type 

(iii) clipper flag 

compositing graphics operations and flags, including 

(i) the raster operation code 

(ii) the alpha channel operation code 

(iii) the "source pop" flag 

(iv) the "destination pop" flag 

(v) the x - independent flag 
- fill rule 

attributes and 
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fill table index. 

The contents of the table 530, where not used in the priority determination 
module 500 are passed as messages to each of the fill colour 'determination module 600 
for pixel generation, and to the pixel compositing module 700 for compositing operations. 

The first edge crossing for scan line 35 (Fig. 12E) is seen in Fig. 15A where for 
P=l, the fill count is updated to the value of the edge according to the non-zero winding 
rule. Because there are no objects beneath, the "need-below" is level set at zero. 

Because a previous state of the table 530 was not set, the arrays 510 and 508 
remain not set and the priority encoder 514 is disabled from outputting a priority. This is 
interpreted by priority generation module 516 which outputs a count n=40 (pixels) for a 
"no object" priority (eg: P = 0), being the first, blank, portion of the scan line 35. 

Fig. 15B shows the arrangement when the edge crossing of Fig. 12F is received. 
The fill count is updated. The arrays 510 and 508 are then set with the previous highest 
level from the table 530. At this time, the module 516 outputs a count n=45, P=l 
representing the edge 96 of the opaque red object 90 before intersection with the 
seraitransparenl triangle 80. 

Fig. 15C shows the arrangement when the edge crossing of Fig. 12G is received. 
Note that the fill count has been adjusted downwardly because of the non-zero winding 
rule. Because the object that is valid prior to receiving the current edge crossing is not 
opaque, the modified priority encoder 512 is used to select the priority P=2 as the highest 
active level which is output as is current for n=(115-85)=30 pixels. 

Fig. 15D shows the arrangement when the edge crossing of Fig. 12H is received. 
Note that previously changed "need-below" fot P=2 has been transferred to the active 
array 508, thus permitting the priority encoder to output a value P=l current for n=(160- 
115)=45 pixels. 

Fig. 15D shows the result when the edge crossing of Fig. 121 is received, 
providing for an output of P=0 for n=(180-160)=20 pixels. 

As such, the priority module 500 outputs counts of pixels and corresponding 
priority display values for all pixels of a scan line. 
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The operation of the fill colour determination module 600 will now be described 
with reference to Fig. 6. Incoming messages 598 from the priority determination 
module 500, which include set fill data messages, repeat messages, fill priority messages, 
end of pixel messages, and end of scan line messages, first pass to a fill lookup and 
control module 604. The fill lookup and control module 604 maintains a current X 
position counter 614 and a current Y position counter 616 for use by various components 
of the fill colour determination module 600. 

Upon receipt of an end of scan line message, the fill lookup and control 
module 604 resets the current X counter 614 to zero and increments the current Y 
counter 616. The end of scan line message is then passed to the pixel compositing 
module 700. 

Upon receipt of a set fill data message, the fill lookup and control module 604 
stores the data in the specified location 602 of the fill data table 36. 

Upon receipt of a repeat message, the fill lookup and control module 604 
increments the current X counter 614 by the count from the repeat message. The repeat 
message is then passed to the pixel compositing module 700. 

Upon receipt of an end of pixel message, the fill lookup and control module 604 
again increments the current X counter 614, and the end of pixel message is then passed 
to the pixel compositing module 700. 

Upon receipt of a fill priority message, the fill lookup and control module 604 
performs operations which include: 

(i) the fill type from the fill priority message is used to select a record size in 
the table 36; 

(ii) the fill table address from the fill priority message, and the record size as 
determined above, is used to select a record from the fill data table 35; 

(iii) the fill type from the fill priority message Is used to determine and select a 
sub-module to perform generation of the fill colour. The sub-modules may 
include a raster image module 606, a flat colour module 608, a linearly ramped 
colour module 610, and an opacity tile module 612; 
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(iv) the determined record is supplied to the selected sub-module 606-612; 

(v) the selected sub-module 606-612 uses the supplied data to determine a 
colour and opacity value; 

(vi) the determined colour and opacity is combined with remaining information 
from the fill colour message, namely the raster operation code, the alpha channel 
operation code, the source pop flag, and the destination pop flag, to form a 
colour composite message, which is sent to the pixel compositing module 700 
via the connection 698. 

In the preferred embodiment the determined colour and opacity is a red, green, 
blue and opacity quadruple with 8-bit precision in the usual manner giving 32 bits per 
pixel. However, a cyan, magenta, yellow and black quadruple with an implied opacity, or 
one of many other known colour representations may alternatively be used. The red, 
green, blue and opacity case is used in the description below, but the description may also 
be applied to other cases. 

The operation of the raster image module 606, the flat colour module 608, the 
linearly ramped colour module 610, and the opacity tile module 612 will now be 
described. 

The flat colour module 608 interprets the supplied record as a fixed format record 
containing three 8-bit colour components (typically interpreted as red, green and blue 
components) and an 8-bit opacity value (typically interpreted as a measure of the fraction 
of a pixel which is covered by the specificd colour, where 0 means no coverage, that is 
complete transparency, and 255 means complete coverage, that is, completely opaque). 
This colour and opacity value is output directly via the connection 698 and forms the 
determined colour and opacity without further processing. 

The linearly ramped colour module 610 interprets the supplied record as a fixed 
format record containing four sets of constants or, cy and d, associated with the three 
colour and one opacity components, and two position values xbase and yfwwe being the 
coordinates of the reference point of the linear ramp. At the reference point, the colour 
and opacity components have their associated d value. 
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For each of the four sets, a result value r is computed by combining three 
constants with the current X and Y coordinates, and the xbase and ybasc constants, using 
the formula: 

r = clamp ( or x (Jt-xhase) + cy X (Y -ybase) +- d ) 
where the function clamp is defined as: 

{ 255 255 <x 

clamp (x) = { |xj 0sx<255 
{ 0 x<0 
In an alternative implementation, the linearly ramped colour module 610 interprets 
the supplied record as a fixed format record containing four sets of three constants, ex, cy, 
and d, being associated with the three colour and one opacity components. For each of 
these four sets, a result value r is computed by combining the three constants with the 
current X count, x, and the current Y count, y, using the formula: 

r = clamp (cxXr + cyXy + rf) 
where the function clamp is defined as above. 

The four results so produced are formed into a colour and opacity value. This 
colour and opacity value is output directly via the connection 698 and forms the 
determined colour and opacity without further processing. 

Other mathematical calculations giving the same result may be used. 
The opacity tile module 612 interprets the supplied record as a fixed format record 
containing three 8-bit colour components, an 8-bit opacity Yalue, an integer X phase, (px), 
a Y phase, {py\ an X scale, (sx), a Y scale, (sy), and a 64 bit mask. These values 
originate in the display list generation and contained typically in the original page 
description. A bit address, a, in the bit mask, is determined by the formula: 
a = ((*/2" i-px ) mod 8 ) + (( y/29 1 + py ) mod'8 ) x 8 
The bit at the address "a" in the bit mask is examined. If the examined bit is one, 
the colour and opacity from the record is copied directly to the output of the module 612 
and forms the determined colour and opacity. If the examined bit is zero, a colour having 



(110) 



«r« 2000-149035 



three zero component values and a zero opacity value is formed and output as the 
determined colour and opacity. 

The raster image module 606 interprets the supplied record as a fixed format 
record containing six constants, a, b, c, d, xbase and ybase; an integer count of the 
number of bits (bpl) in each raster line of the raster image pixel data 16 to be sampled; 
and a pixel type. The pixel type indicates whether the pixel data 16 in the raster image 
pixel data is to be interpreted as one of: 

(i) one bit per pixel black and white opaque pixels; 

(ii) one bit per pixel opaque black or transparent pixels; 
(ili)8 bits per pixel grey scale opaque pixels; 

(iv) 8 bits per pixel black opacity scale pixels; 

(v) 24 bits per pixel opaque three colour component pixels;, or 

(vi) 32 bits per pixel three colour component plus opacity pixels. 
Many other formats are possible. 

The raster image module 606 uses the pixel type indicator to determine a pixel 
size \bpp) in bits. Then a bit address, a, in the raster image pixel data 16 is calculated 
having the formula; 

a = bpp * [a X(x- xbase) + cX(v- ybase)] 

+ bplx[bx(x' xbase) + <i X (y - ybase) J . 

A pixel interpreted according to the pixel type from the record 602 is fetched from 
the calculated address "a" in the raster image pixel data 16. The pixel is expanded as 
necessary to have three eight bit colour components and an eight bit opacity component 
By "expanded", it is meant for example, that a pixel from an eight bit per pixel grey scale 
opaque raster image would have the sampled eight bit value applied to each of the red, 
green and blue component, and the opacity component set to. fully opaque. This then 
forms the determined colour and opacity output 698 to the pixel compositing module 700. 

As a consequence, the raster pixel data valid within a displayable object is 
obtained, through the determination of a mapping to the pixel image data within the 
memory 16. This effectively implements an affine transform of the raster pixel data into 
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the object-based image and is more efficient than prior art methods which transfer pixel 
data from an image source to a frame store where compositing with graphic object may 

As a preferred feature to the above, interpolation between pixels in the raster 
image pixel data 16 may optionally be performed by first calculating intermediate results 
p, and q according to the formulae: 

p = a x (x-xbase) + c x (y - ybase) 
q = bx(x-xbase) * dx(y-ybase). 
Next the bit addresses, -Jfjo, a 0 l. "10. a U> of f° ur P« cls in rastw ima S c 
pixel da,ta 16 are determined according to the formulae: 
a m = bpp\[p\^bplxYq\ 
"01 s a 00 + b PP 

a io = «oo + M 

"11 = «00 + bpl 1-bpp 

Next, a result pixel component value, r, is determined for each colour and opacity 
component according to the formula: 

r s= interp ( interp 
where the function interp is defined as: 

interp {a, b, c) = a + (fc-a) X (c-lc|) 

In the above equations, the representation [value] = floor {value), where a/7oor 
operation involves discarding the fractional part of value. 

The get function returns the value of the current pixel component sampled from 
the raster image pixel data 16 at the given bit address. Note that for some components of 
some image types this can an implied value. 

As a preferred feature to the above, image tiling may optionally be performed by 
using x and y values in the above equations which are derived from the current X and V 
counters, 614, 616 by a modulus operation with a tile size read from the supplied record. 

Many more such fill colour generation sub-modules are possible. 
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The operation of the pixel compositing module 700 will now be described, 
locoming messages from the fill colour determination module 600, which include repeat 
messages, colour composite messages, end of pixel messages, and end of scan line 
messages are processed in sequence. 

Upon receipt of a repeat message or an end of scan line message, the pixel 
compositing module 700 forwards the message to a pixel output FIFO 702 without further 
processing. 

Upon receipt of a colour composile message the pixel compositing module 700 
typically, and in general terms combines the colour and opacity from the colour 
composite message with a colour and opacity popped from the pixel compositing stack 38 
according to the raster operation and alpha channel operation from the colour composite 
message. It then poshes the result back onto the pixel compositing stack 38. A 
description of the processing performed upon of receipt of a colour composite message is 
given below. 

Upon receipt of an end of pixel message, the pixel compositing module 700 pops a 
colour and opacity from the pixel compositing stack 38, with the exception that if the 
stack 38 is empty an opaque white value is used. The resultant colour and opacity is 
formed into an pixel output message which is forwarded to the pixel output FIFO. 

A known compositing approach is that described in "Compositing Digital 
Images', Porter, T; Duff, T; Com puter Grap hics. Vol. 18 No. 3 (1984) pp. 253-259. 
Examples of Porter and Duff compositing operations are shown in Fig. 21. However, 
such an approach is deficient in that it only permits handling source and destination 
colour in the intersecting region formed by the composite and, as a consequence, is 
unable to accommodate the influence of transparency in the intersecting region. This 
results in the raster operations defined by Porter and Duff as being essentially inoperative 
in the presence of transparency. ' - 

The processing performed by the pixel compositing module 700 upon receipt of a 
colour composite message will now be described. 
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Upon receipt of a colour composite message, the pixel compositing module 700 
first forms a source colour and opacity. This is taken from the colour and opacity 
provided in the colour composite message unless the pop source flag is set in the colour 
composite message, in which case the colour is popped from the pixel compositing 
stack 38 instead. If at this time, or during any pop of the pixel compositing stack, the 
pixel compositing stack 38 is found to be empty, an opaque white colour value is used 
without any error indication. Next, a destination colour and opacity is popped from the 
pixel compositing stack 38, except that if the destination pop flag is not set in the colour 
composite message, the stack pointer is not disturbed during the "pop" operation, in effect 
making this a read from top of stack 38 instead. 

The method of combining the source colour and opacity with the destination 
colour and opacity will now be described with reference to Figs. 7A to 7C. For the 
purposes of this description, colour and opacity values are considered to range from 0 
to 1, (ie: normalised) although they are typically stored as 8-bit values in the range 0 
to 255. For the purposes of compositing together two pixels, each pixel is regarded as 
being divided into two regions, one region being fully opaque and the other fully 
transparent, with the opacity value being an indication of the proportion of these two 
regions. Fig. 7A shows a source pixel 702 which bas some three component colour value 
not, shown in the figure and an opacity value, (so). The shaded region of the source 
pixel 702 represents the fully opaque portion 704 of the pixel 702. Similarly, the non- 
shaded region in Fig.7A represents that proportion 706 of the source pixel 702 
considered to be fully transparent. Fig. 7B shows a destination pixel 710 with some 
opacity value, (do). The shaded region of the destination pixel 710 represents the fully 
opaque portion 712 of the pixel 710. Similarly; the pixel 710 has a fully transparent 
portion 714. The opaque regions of the source pixel 702 and destination pixel 710 are, 
for the purposes of the combination, considered, to be orthogonal to each other. The 
overlay 716 of these two pixels is shown in Fig. 7C. Three regions of interest exist, 
which include a source outside destination 718 which has an area of so t (1 - do), a 
source intersect destination 720 which has an area of so x do. and a destination outside 
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source 722 which has an area of (1 - so ) X do. The colour value of each of these three 
regions is calculated conceptually independently. The source outside destination 
region 718 takes its colour directly from the source colour. The destination outside 
source region 722 lakes its colour directly from the destination colour. The source 
intersect destination region 720 takes its colour from a combination of the source and 
destination colour. The process of combining source and destination colour, as distinct 
from the other operations discussed above is termed a raster operation and is one of a set 
of functions as specified by the raster operation code from the pixel composite message. 
Some of the raster operations included in the preferred embodiment are shown in Table 2. 
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TABLE 2 



Raster 
operation 
code 


Operation 


Comment 


0x00 


r=0 


BLACKNESS 


0x01 


r = src & dest 


SRCAND 


0x02 


r=src&~dest 


SRCERASE 


0x03 


r= src 


SRCCOPY 


0x04 


r = -src & dest 




0x05 


r = dest 


NOP 


0x06 


r = src A dest 


SRCINVERT 


0x07 


r = src dest 


SRCPAINT 


0x08 


r = ~{src | dest) 


NOTSRCERASE 


0x09 


t = ~(src A dest) 




0x0a 


r=-dest 


DSTINVERT 


0x0b 


r = src | -dest 




OxOo 


r = ~src 


NOTSRCCOPY 


OxOd 


r = -src | dest 


MERGEPAINT 


OxOe 


r = ~(src&dest) 




OxOf 


r = Oxff 


WHITENESS 


0x10 


r = nrin(src, dest) 




OxII 


r = max(src, dest) 




0x12 


r = clamp(src + dest) 




0x13 


r=src 




0x14 


r — clamp(src - dest) •■■ 




0x15 


r = dest 




0x16 


r = clamp(dest - src) 




0x17 


r = clamp(src + dest) 
where dest Is signed 




0x18 


r = threshold (dest, src) 




0x19 


r = threshold (src, dest) 




Oxla 


r=~dest 




Oxlb 


o = luminance (dest, src) 




Oxlc 


r = ~src 




Oxld 


o = ckey(dest; src +/- o) 
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Each function is applied to each pair of corresponding colour components of the 
source and destination colour to obtain a like component in the resultant colour. Many 
other functions are possible. 

The alpha channel operation from the composite pixel message is also considered. 
The alpha channel operation is performed using three flags, each of which corresponds to 
one of the regions of interest in the overlay 716 of the source pixel 702 and the 
destination pixel 710. For each of the regions, a region opacity value is formed which is 
zero if the corresponding flag in the alpha channel operation is not set, else it is the area 
of the region. 

The resultant opacity is formed from the sum of the region opacities, Each 
component of the result colour is then formed by the sum of the products of each pair of 
region colour and region opacity, divided by the resultant opacity. 

The resultant colour and opacity is pushed onto the pixel compositing stack 38, 

Expression trees are often used to describe the compositing operations required to 
form an image, and typically comprise a plurality of nodes including leaf nodes, unary 
nodes and binary nodes. A leaf node is the outermost node of an expression tree, has no 
descendant nodes and represents a primitive constituent of an image. Unary nodes 
represent an operation which modifies the pixel data coming out of the part of the tree 
below the unary operator. A binary node typically branches to left and right subtrees, 
wherein each subtree is itself is an expression tree comprising at least one leaf node. 

When compositing with arbitrary shaped objects, there arises a problem that the 
various stack operations mentioned above are different for different areas of the image, 
these depending upon those objects that are active at particular locations. 

Figs, 17A and 17B show a typical binary operation (illustrated as an expression 
tree) between source (S) and destination (D). Regardless of the actual operation being 
performed, the binary operation of Fig. 17A resolves into four cases or regions of activity 
as indicated below; 

1. (A)S active, (B)D inactive; 

2. (A)S active. (Bp active; 
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3. (A)S inactive, (B)D active; and 

4. (A)S inactive, (B)D inactive. 

Case 4 always results in no operation (NOP) being required to be performed and 
as a consequence, there exists three different combinations of active levels for a binary 
tree. Extensions of this concept to tertiary, quaternary and higher order trees will be 
apparent to those skilled in the art. 

As a consequence, when building the compositing stack 38 (for the binary 
example), one of the three above identified operations is required to be implemented by 
the stack. Further, the different operations associated with each object in the stack 
depend upon what is below the object in the level activation table. For rendering of 
objects using simple OYER operations, as occurs in the Painter's Algorithm, this poses no 
problem. However for other compositing operations, the stack operations need to be 
changed depending on the activity of the operands of the compositing operation. While 
this can be done by clipping the levels providing the stack operations, the number of clips 
applying to each level can rapidly rise, creating difficulties in handling the stack 
operations. Examples of problematic operations are the Porter and Duff operations OUT 
and ROUT as seen in Fig. 21 where an object (operand) clips (alters the boundary of) the 
other object and has variable transparency in the intersection region. 

In order to address this problem, a further table, noted herein as an "activity" table 
is provided which acts as an adjunct to the level activation table to provide for a logical 
determination of the alternative actions mentioned above. 

Fig. 18A illustrates a generic activity table 800 which includes essentially three 
sections.' A first' section 802 provides activation conditions for a specific fill level being 
processed. The second section 804 includes each of the different actions referred to 
above as appropriate for the respective levels (specifically for the binary example). The 
third section 806 indicates whether the source or destination object is active at the 
particular level. It is noted that the entries contained in the action section 804 may be the 
specific operations themselves or alternatively pointers to the level activation table where 
appropriate. 
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It is also noted (hat the various operations can provide data to other operations in 
some cases, but not in others. As a consequence, the activity tabic 800 can be modified to 
incorporate flags indicating various conditions for which the operation provides data. 

A data structure for a preferred form of the activity tabic is seen in Kg. 18B as the 
table 810. The table 810 includes a pointer 814 (Next Level) to an entry for the next 
operation which uses the data, and a flag 806 (or a set of flags where tertiary and higher 
order trees are being used) that indicates the branch of the expression tree for which the 
operation is providing data (Src_Aaive/Dest_active). The table 810 also includes a 
flag 816: that indicates whether the operation is providing data In the source or destination 
branch. If so, the Srcjtctlve or Dest_Active flags. 806 in the next level entry are adjusted 
accordingly when an activity state 818 of the operation changes. Since an operation only 
provides data in certain combinations, further flags 812 (datajnj*) are provided to 
Indicate this. The flags 812, in combinations with the Src/Dest_Active flags 806, 
determine the activity state of a level. Further, since any operation only has to alter the 
state of the next level if its own activity state changes, the node active flag 818 is 
provided, to monitor such a situation. 

For right leaf nodes, it is therefore necessary to activate a Push operation and the 
Dest active flag in the next operation record. For left leaf nodes, it is necessary to 
activate the Srcjictive flag on an edge crossing, noting that the destination may already 
be active. 

" In Fig. 18B, the activation conditions 802 include the fill rule which determines 
activation of leaf nodes, and the fill count which is used in the manner as described above 
for the level activation table. The clip count operates also in the manner described above. 
Edge crossings activate (source) levels in the table 810. 

When an activation state of a level changes, the change propagates to the level 
pointed to by the Nexi Level entry 814. Depending upon the state of the Datajsjrc 
flag 816, the Src_ActivetDest_Active flag 806 is changed in the next level The change 
propagates if the state of the next level also changes. The table, entries contain operations 
for cases 1, 2 and 3 respectively. These may be pointers to levels within the level 
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activation table, or actual operations (eg. Alpha operation, colour operations, fill type and 
stack operation flags). Alternatively, they may be NULL if no operation is required. 

The activation state of a node level is determined by whether there is data for the 
next operation in the expression tree, as determined by the datajn flags 812 for each of 
S (~l Dop,S (1 Dop,S n Dop and the Src I Destjtctive flags 806 for the node level. This 
is depicted in the table as a Node_Active flag 818. 

A specific example of this implementation is shown for an expression tree 830 
seen in Fig. 19, and with a corresponding initial activity table 820 seen in Fig. 20A. 

The expression tree 830 provides for the rendering of operands^, B and C onto a 
page, where the latter, for the sake of completeness is seen in the tree 830 as a right leaf 
node, PAGE. PAGE is always active and encompasses the entire image output space and 
therefore it may be omitted from the activity table 820. 

Since B and C are leaf nodes, these form the lower levels of the table 820 and each 
result in activation operations 804 that can cause a push of the respective operator onto 
the compositing stack. Since each are right leaf nodes, C is pushed first, and the 
SCiDop is a NOP because nothing operates on operand C The datajnjop flags 812, 
Next Level 814 and DataJs_Src 816 flags are also updated. Operand B results in 
corresponding actions. 

The next level in the activity table 820 is formed by the left leaf node A, and its 
corresponding operator Op2. Activation operations 804 for this level are updated with 
each of IfXDop and SCiDop being Aop2B each modified by a qualifier a or b 
respectively depicting the differences between the operations. The operation Op2 only 
provides data in S, and this is represented by an activity which pops B off the stack if D is 
active and S is not (ie. S P Dop ). 

The next level in the table 820 relates to Opl and produces respective qualified 
results a, b and c in the activation operations 804. For the final level over, since PAGE is 
always active, S C\ Dop and S n Dop result in NOP to be pushed onto the stack. Only in 
the simple intersection SHDop, is over active. 
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For this example, let us consider what happens if A, B and C are initially inactive, 
and those operands are subsequently activated in turn. 

It A is activated first, then^Op2a is activated on this level, reflected by the setting 
of the Src_Active flag 806. Since the S D D flag 812 is set (since B is not yet active), the 
Node_Active flag 818 is then set for the level. Since the State of Node Active has 
changed, the Src_Active flag 806 in the Opl level is set. Note that DatajsjSrc 816 is set 
for AOp2 level. The Opl level has Src_Active and Dest_Active (since C is yet to be 
activated) so Opla is activated on this level. Since S n D is set, Node_Active 818 is then 
set for the Opl level. Since the state of Node_Active 818 has changed, the Src_Active 
flag 806 in the over level is set. Since the over level has Src_active and Dest_Active 
(because PAGE is always active), then over is activated on this level. Since SOD is set, 
Nodejlcttve is set and the state of Node_Active. has not changed. No further action is 
then required. The compositing stack 38, al this stage may be established from the 
table 820 to appear as seen in Fig. 20B. 

Turning now to Fig. 20C, if B is activated next, Push B is activated on this level 
since S DD is set (and D is irrelevant, anyway). Node_Active 818 is set for this level. 
The state otNode_Acth>e has changed, and therefore Destjictive flag in \heAOp2 level is 
set. AOplbB is then activated, and AOp2aB, is deactivated. Since SHD is set, 
Node_Active remains set and the state ofNodejtctive is unchanged for AOpTa. No 
further action results. The compositing stack 38 then appears as scon in Fig. 20D. 

" As seen in Fig. 20E, if C is activated next, Push C is activated on this level. Since 
S is active and D is irrelevant, Node_Active 818 is set for this level. Since Nodejtctive 
has changed, the Destjictive flag in Opl level is then set. Oplb is activated so Opla is 
deactivated. Since data in SHD is set, Node_Active remains set. Since Node_Acdve is 
unchanged for the Opl level, no further action is required. The compositing slack 38 then 
appears as seen in Fig. 20F. 

This .procedure continues for the evaluation of the entire expression tree of Fig. 19, 
thus providing for the activity table 820 to be established in such a way that various 
operations are established which may then be pushed onto the compositing stack as 
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required by the various activation conditions 802 and activity indicators 804. In this 
fashion, regardless of the type of clipping or other operation being performed, the stack is 
able to be maintained with the correct operation at the correct level irrespective of the 
complexity of the expression tree being evaluated. Significantly, whilst the bulk of the 
expression tree is evaluated through the formation of the display list, generation of the 
display list is typically unable to account for variations in the operation of various objects 
such as clipping, these operations being required lo implemented during the evaluation of 
the compositing expression. 

It is further noted that further flags, one for srcJs_leaf_node, which may be 
activated by edge crossings, and another fatdestJs_PAGE (always active), can be useful. 
If dest_is_PAGE, it is possible to ignore the S D D case as this never happens. 

The above illustrates how the activity table 820 is built based on the structure of 
the expression tree 830, and has its entries completed (ie. filled in) through the changing 
activation of the various operands of the tree 830. For the specific example of the 
table 820, 72 (=2x2x3x3x2) stack structures can arise to account for the different 
activations and possible outcomes. In this fashion, logical evaluation of the conditions 
802, 806, 812, 814, 816 and 818 results in the correct activity 804 being identified as the 
appropriate stack operation for the particular level. 

In an alternative implementation, rather than being constructed as an independent 
table, the activity table 820 may be merged into the level activation table 530 to give a 
combined table 830. This avoids the replication of data whilst permitting the priority 
encoders 512,514 to select not only the correct edge priority but also activation operation, 
the Utter being transferred (progressively) to the pixel compositing stack 38 for 
evaluation by the compositing module 700 using the fill colours derived from the module 
600. such an arrangement is depicted functionally in Fig. 20G. 

Alternatively, as seen functionally in Fig 20H, the activity table 820 may precede 
the level activation table 530. In such a case, columns for fill count and clip count are 
included in the activity table 820 and may be omitted from the level activation table 530. 
In a further alternative configuration, shown functionally in Fig. 201, the activity 
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table 820 may follow the level activation table 530. In that case, the activity table 820 
can omit fill count and clip count as these are included in the level activation table 530. 
In some applications, where an activity table 820 is configured as shown in Fig. 20A, the 
level activation tabic 530 may be omitted. 

The operation codes described above with reference to the activity table 820 and 
the stack 38 derive from the display list and the instruction stream 14 in particular (see 
Fig. 3). The operation codes are transferred in parallel with other data (eg. edge 
crossings, fill data, etc) through the pipeline of processing stages shown in Fig. 3 and the 
pixel compositing module 700 places the op codes onto the stack in the order determined 
as a consequence of priority determination, level activation and fill determination. 

The operation of the pixel output module 800 will now be described. Incoming 
messages are read from the pixel output FIFO, which include pixel output messages, 
repeat messages, and end of scan line messages are processed in sequence. 

Upon receipt of a pixel output message the pixel output module 800 stores the 
pixel and also forwards the pixel to its output Upon receipt of a repeat message the last 
stored pixel is forwarded to the output 898 as many times as specified by the count from 
the repeat message. Upon receipt of an end of scan line message the pixel output 
module 800 passes the message to its output. 

The output 898 may connect as required to any device that utilizes pixel image 
data. Such devices include output devices such as video display units or printers, or 
memory. storage devices such as hard disk, semiconductor RAM including line, band or 
frame stores, or a computer network. 

One difficulty with implementing the system described so far is that, in many 
cases, it does not deal adequately with compositing of objects comprising pixels having 
associated opacity values. In particular, in some situations, overlapping objects are 
incorrectly composited at points along a scan line where one or more of the objects is not 
active. The situation in the present embodiment arises with Porter and Duff compositing, 
and will be described with reference to that particular compositing scheme. However, it 
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will be appreciated that the aspects of the invention described in detail below can also be 
applied to similar difficulties arising under other compositing schemes. 

For example, the expression PAGE *-(AinB) over (C out D) over PAGE can be 
represented as a binary tree structure 1000, as shown in Fig. 22, where A, B, C and D are 
different graphical objects being defined by edges, a viewing priority and opacity data. A 
level activation table 1001 for this example is shown in Fig. 23, in which it will be seen 
that line 1002 implements the C out D portion of the expression shown In Fig. 22. 
Unfortunately, using this configuration, if D is inactive at a certain pixel, the out 
operation will incorrect! y be performed with PAGE rather than D. K C is not opaque, this 
results in a visually incorrect appearance upon rendering. To avoid this type of problem, 
where objects having an opacity which is potentially less than 1, an inactive object must 
not appear in a compositing expression at a position other than to the left of an over 
operation. Given that most objects will be inactive for at least some portion of every scan 
line on which they appear, this can be a major problem. 

One way of overcoming the problem is to "pad out" objects, using transparent 
pixels. In this way, the Porter and Duff expression is correctly applied, because each 
object effectively exists, at every point at which the object it is being composited with 
exists. Applying this to the example above, each leaf node (ie, A, B, C and D) in the 
binary tree 1000 is replaced with an expression placing it over a transparent (glass) object 
the size of the bounding box around a union of the pairs of objects, as illustrated ia 
Figs. 24 and 25. 

In Fig. 24, two transparent glass bounding boxes Ol and G2 arc shown. Gl 
represents a bounding box of A and B, whilst G2 represents a bounding box of C and D. 
Implementing this in the expression tree 1000 results in a modified expression tree 1004, 
shown in Fig, 25. A corresponding level allocation table 1005 is shown in Fig. 26. As 
will be apparent from the level allocation table 1005 and the modified expression 
tree 1004, this modification results in a substantial increase in the number of stack 
operations required for each pixel. This is because stack operations are performed where 
one or both of a pair of pixels being composited is transparent. In terms of the actual 
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rendered output ultimately achieved, these operations arc relatively wasteful of stack 
resources and processor time. 

One way of reducing the number of operations is to clip out the glass objects with 
the leaf-node objects they are composited with. The over operation between leaf nodes 
and the transparent objects is then no longer required. In view of the fact that clipping 
operations arc, in general, less processor intensive than multiple compositing operations, 
this results in more efficient operation of the stack. 

A level activation table 1006 for the example above using clipping of the 
transparent boxes Gl and 02 with A and£, and C and/), respectively, is shown in Fig. 27. 
It will be noted that only eight stock operations are performed per pixel in this 
implementation, compared with twelve operations in the case where A, B, C and D are 
padded using multiple over operations. Four of these levels arc clipping levels 999. It 
will be appreciated, however, that a number of redundant compositing operations 
involving transparent pixels are still required. 

A preferred method of correctly implementing Porter and Duff compositing where 
one or more over lapping objects are non-opaque will now be described. Referring to the 
example shown in Fig. 28, it will be noted that the operation C out D can be represented 
in three ways, one for each of regions CC\D, CDD and CTU). Region CD£> can be 
represented .by C, since there is no contribution from D in that region for an our operation, 
and C is required. In region CHD, both C and D are active, and so compositing using the 
C out D operation is required. There is no contribution from C or D in the region CClD, 
and so the region need not be considered when building the compositing stack for pixels 
in that region. 

A simplified representation of the C out D operation is given in Figs 42 and 43. In 
Fig, 42 there are shown objects C and D, for which the out operation is to be performed. 
As described above, the scan line can be divided into three regions: COD, COD and CD 
D. In the present case, if C is non-opaque, the out operation will incorrectly be 
performed with PAGE in the region COD. 
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Fig. 43 illustrates the solution previously described. It will be noted that each of 
the objects is clipped to the region in which it is active. Region CDD is simply 
represented by a level CI, region COD is represented levels CI and Dl, whilst region C 
V\D requires no input from cither icveL It will be appreciated that using the specific 
requirements of particular operations to control clipping of objects to only required 
regions results in a considerably smaller number of compositing operations, as transparent 
padding pixels are no longer required. 

A level activation table 1008 for implementing the dipping of this example is 
shown in Fig. 29. It will be seen that four additional levels are required in the level 
activation table 1008 compared to the previous method described. However, three out of 
four of these additional levels are clipping levels 1015, which are typically less intensive 
than compositing operations. Also, the actual compositing stack produced for each pixel 
is, on average, smaller than that for the earlier method described. This is due to the fact 
that clipping operations are used to ensure that compositing operations only take place in 
the regions where they are relevant. In effect, processor time is not wasted compositing 
pixels which do not contribute to the final image. 

Compositing stack operations for non-trivial Porter and Duff compositing 
operators are shown in Figs 30 and 31. Table 1010 shown in : Fig. 30 assumes that D is 
already on top of the stack where D is active, and the compositing operators are broken 
down according to the regions to which they apply, It will be noted that alpha channel 
(opacity) operation is restricted to the intersection region 5fU> by activating on S edges 
and, clipping with D edges. Li the cases marked with asterisks, all of the objects which 
contribute to D need to be clipped in by the edges of S. 

The table 1016 shown in Fig, 31 provides the operations where the S pixel value is 
already on the stack, in those regions where it is active. Note that in such a case, the D 
pixel value is on the next level down, where D is also active. In the cases marked with 
asterisks, the stack would be in an incorrect state; cither the objects in the "active branch" 
must be clipped by the objects in the "inactive" branch to prevent the state from 
occurring, or the top value must be popped off the stack. 



(126) 



<&m 2000-149035 



For complicated expressions, the objects may have been built up from several 
other objects, so that the shape of the regions S and D need to be determined from the 
shapes that were used to build them up. The steps required to implement this more 
complicated case will be apparent to those skilled in the art of Porter and Duff 
compositing operations. 

The resulting active regions produced by the various compositing operations are 
given in tabic 101 1 shown in Fig. 32. 

When analysing an expression tree for rendering using the preferred embodiments, 
an application needs effectively to determine the active region of each branch node of the 
tree and pass it on to the next node up the tree. A detailed analysis of the expression tree 
shown in.Fig. 22 will now be undertaken along these lines, in conjunction with Figs. 33 
to41. 

Fig. 33 shows a preliminary analysis of the expression tree 1000 shown in Fig. 22, 
on the basis of active regions arising from the operations associated with each node. 
Referring to Fig. 34, it can be seen that the A in B expression is limited in activity to the 
intersection region of A and B. Accordingly, the edges of object/1 are used to clip object 
B, so that ii does not leave colour on the stack where it is not required. Similarly, the 
level which performs the in operation is restricted to the intersection region by object B. 
The necessary stack operations to achieve this are shown in Fig: 35. 

The same effect could be obtained by using the edges of object B to activate both 
levels, and clipping both with object A, saving a clipping level. However, both clipping 
objects will be required by objects higher up the expression tree. 

The next branch is the over operation, as shown in Fig. 36, in which the active 
regions for the two branches arc as shown. The regions to be considered are shown in 
Fig. 37. The boxed text 1012 at the right of Fig. 37 shows the state of the stack for each 
of the corresponding regions 1013 to the left. 

In the latter two cases, the result of the over operation is already on the stack. 
Accordingly, the intersection region is the only one where a further operation is needed. 
The resulting level activation table entries are shown in Fig. 38. It will be seen that object 
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C activates level 01, and/1 and B clip it to the regionXnflnC. The operation as a whole 
contributes to pixels in the region (AOBJUC. 

This region is passed up to the next node in the expression tree, being the final 
over, which composites the expression onto PAGE. The relevant regions to be considered 
for each of the two branches are shown in Fig. 40, where, again, boxed text 1014 at the 
right hand side shows the stale of the stack for the corresponding active regions 1015 on 
the left hand side. 

To obtain correct operation of the pixel stack for a union operation requires some 
effort One solution is to break up the area into mutually exclusive areas, and to use two 
levels for the same operation. This can be done using the active regions of each branch of 
the previous node to activate one of the levels. The active region of one of the levels is 
then used to dip out the other. For example, area C and area AHBriC can be used to 
make up (ACiB)UC, as will be appreciated by those skilled in the art. 

The resulting entries for the level activation table 1020 for the example expression 
are shown in Fig. 41. Levels 02 (activated by object C) and 03 (activated by object A, 
Clipped in by B and clipped out by C) combine to clip the final over operation to the 
region (ArVB)UC. 

It will be noted that the clipping levels do not contribute to the compositing of the 
pixels. The number of contributing levels, and therefore of stack operations for each 
pixel, is, on average, considerably less than for the method where levels are padded out 
with transparent pixels. Also reduced is the number of pixels for which a particular level 
can be expected to be active in a given scan line. 

It will be appreciated by those skilled in the art that compositing of objects over 
larger numbers of levels is also possible by extrapolating the method described herein. 
Furthermore, it will also be appreciated that the various manipulations shown can be used 
in different compositing paradigms, including framestore-bascd systems and other stack- 
based, line- or band-based compositing systems. 

It will be apparent from the foregoing that the method and apparatus described 
provide for the rendering of graphic objects with full functionality demanded by 
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sophisticated graphic description languages without a need for intermediate storage of 
pixel image data during the rendering process. 

The foregoing describes only a number of embodiments of the present invention, 
and modifications, may be made thereto without departing from the spirit and scope of the 
present invention, various aspects of which are appended hereto. 

4. Brief Description of the Drawings 

Fig. 1 is a schematic block diagram representation of a computer system 
incorporating the preferred embodiment; 

Fig. 2 is a block diagram showing the functional data flow of the preferred 
embodiment; 

Fig. 3 is a schematic block diagram representation of the pixel sequential 
rendering apparatus and associated display list and temporary stores of the preferred 
embodiment; 

Fig. 4 is a schematic functional representation of the edge processing module of 

Fig.2; 

Fig, 5 is a schematic functional representation of the priority determination 
module of Fig. 2; 

Fig. 6 is a schematic functional representation of the fill data determination 
module of Fig. 2; 

Figs, 7A to 7C illustrate pixel combinations between source and destination; 

Fig. 8 illustrates a two-object image used as an example for explaining the 
operation of preferred embodiment', 

Figs. 9A and 9B illustrate (he vector edges of the pbjects of Fig. 8; 

Fig, lOfllustrates the rendering of a number of scan lines of the image of Fig. 8; 
. Fig. 1 1 depicts the arrangement of an edge ; record for tbe image of Fig. 8; 

Figs. 12A to 12J illustrate the edge update routine implemented by the 
arrangement of Fig. 4 for the example of Fig. 10; 

Figs. 13A and 13B illustrate the odd-even and non-zero winding fill rules; 
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Figs. 14A to 14E illustrate how large changes in X coordinates contribute to spill 
conditions and how they are handled; 

Figs. 15A to 15E illustrates the priority filling routine implemented by the 
arrangement of Fig, 5; 

Figs. 16A to 16D provide a comparison between two prior art edge description 
formats and that used in the preferred embodiment; 

Figs. 17A and 17B show a simple compositing expression illustrated as an 
expression tree and a corresponding depiction; 

Fig. 18A depicts a table configured for ensuring accurate stack operations; 

Fig. 18Bis a preferred form of the table of Fig. 18A; 

Fig. 19 is an example expression tree; 

Figs 20A to 20F depict an activity table evaluation of the expression of Fig. 19 
and the corresponding compositing stacks during such evaluation; 

Figs. 20G to 201 depict various configurations of the activity table and associated 
modules; 

Fig. 21 depicts the result of a number of compositing operations; 

Fig. 22 shows <an expression tree for implementing a series of Porter and Duff 
compositing operations on objects A, B, C and D; 

Fig 23 shows a level activation table for implementing the binary tree structure 
shown in Fig. 22; 

' Fig. 24 shows the objects of the binary tree shown in Figure 22 placed over 
transparent glass objects; 

Fig. 25 shows a modified expression tree for implementing the arrangement 
shown in Fig. 24; 

Fig. 26 shows a level activation tabic for implementing the expression tree of 
Figure 25; 

Fig. 27 shows an alternative level activation table for the example shown in 
Figs. 24 and 25, in which the transparent boxes are clipped with A,B,C and D; 
Fig. 28 shows an expression tree for the operation C out D; 
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Fig. 29 shows a level activation tabic for implementing the clipping shown in 
Fig. 28; 

Figs. 30 and 31 show compositing stack operations for non-trivial Porter and Duff 
compositing operators; 

Fig. 32 shows active regions far various operators; 

Fig. 33 shows a similar expression tree to that shown in Fig. 22, with a 
preliminary analysis of the steps involved in implementing the expression; 

Fig. 34 shows the active regions for theA in B expression from the expression tree 
shown in Fig. 33; 

Fig. 35 shows stack operations necessary to perform the in operation shown in 
Fig. 34; 

Fig. 36 is a detailed view of the over operation of Fig. 33, showing active regions 
from the in and out operations below; 

Fig. 37 shows a state of the stack for each of the regions to be considered in 
relation to the expression of Fig. 36; 

Fig. 38 shows level activation table entries for implementing the operation shown 
in Figs. 36, and 37; ' • , 

Fig. 39 shows the final over operation from the expression tree of Fig. 33, 
indicating the active regions from the over and page expressions below; 

Fig, 40 shows the regions to be considered in the expression of Fig. 39; 

Fig. 41 shows the resulting entries for the level activation tabic for implementing 
the expression shown in. Fig. 39; 

Fig. 42 shows a C out D operation prior to implementing clipping to active 
regions; and 

Fig. 43 shows the C out D operation after clipping Ihe individual levels to their 
active regions. 
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1. ABSTRACT 

Disclosed arc mclhods, apparatus (1) and computer readable media for rendering 
at least one graphic object (80, 90) described by at least one edge (82-86, 92-98) into a 
raster pixel image (78) having a plurality of scan lines and a plurality of pixel locations on 
each scan line. For each scan line, coordinates of intersection of those edges of the 
objects that intersect the scan line are determined in a predetermined order. This is 
preEerably achieved by processing edge records (418) using a number of buffers (402, 
404,406, 412,420, 422) thereby enabling efficient sorting of edge intersections into order. 
For each adjacent pair of edge intersections, information (530) associated with the 
corresponding object is examined to determining a set of active objects (508, 510) for a 
span of pixel locations between the corresponding pair of edge intersections. For each 
span of pixel locations, the corresponding set of active objects is used to determine (600) 
a value for each of the locations within the span. The information may include one or 
more of a fill count, a clip count and other factors. A compositing model accommodating 
opacity is also disclosed, as arc stack operations used to facilitate rendering and other 
features which contribute to fast processing of image components. 

2. Rep resentati ve Drawing 

Fig. 1 



